时间:2021-05-20
由于需要用MongoDB缓存数据,所以自己写了一套公共的存放和读取方法
具体如下:
存放mongodb:
/** * 公共方法:设置Object类型缓存 * @author shijing * @param param * @param sysGuid */ public void setObjData(Map<String,Object> param, String sysGuid, String enumBpd){ DBObject dbObject = new BasicDBObject(); dbObject.putAll(param); String collectionName = EnumBpd.getBpdType(enumBpd) + sysGuid; mongoDao.insertToCol(dbObject,collectionName); } /** * 公共方法:设置List缓存 * @author shijing * @param paramList * @param sysGuid */ public void setListData(List<Map<String,Object>> paramList, String sysGuid, String enumBpd){ List<DBObject> list = new ArrayList<>(); if(CollectionUtils.isNotNull(paramList)){ for (Map<String,Object> param : paramList){ DBObject dbObject = new BasicDBObject(); dbObject.putAll(param); list.add(dbObject); } } String collectionName = EnumBpd.getBpdType(enumBpd) + sysGuid; mongoDao.insertToCol(list,collectionName);mongoDao里面的方法:
public void insertToCol(DBObject document, String collectionName) { dropCol(collectionName); DBCollection dbCollection = mongoTemplate.createCollection(collectionName); dbCollection.insert(document); } public void insertToCol(List<DBObject> documents, String collectionName) { dropCol(collectionName); DBCollection dbCollection = mongoTemplate.createCollection(collectionName); dbCollection.insert(documents); }读取方法
/** * 通过关键字模糊查询问题和答案库 * @param param * @return */ @Override public List<Map<String, Object>> searchQuestionAndAnswerByKeyword(Map<String, Object> param) { List<Map<String,Object>> searchList = new ArrayList<>(); Map<String,Object> userInfo = SessionUtils.getUserInfo(); String sysGuid = userInfo.get("sys_guid").toString(); String collectionName = EnumBpd.getBpdType(EnumBpd.HELP_PAGE_LIST.getType())+sysGuid; //注释里面这种方式虽然能模糊查询,但是容易漏掉数据,切记切记!!! //Pattern pattern = Pattern.compile("^.*" + param.get("keyword") +".*$", Pattern.CASE_INSENSITIVE); BasicDBObject query= new BasicDBObject(); //模糊查询的字段设置 query.put("page_html", Pattern.compile((String) param.get("keyword"))); DBCursor dbCursor = mongoDao.findAll(query,collectionName); List<DBObject> list = dbCursor.toArray(); for (DBObject dbObject: list){ searchList.add(dbObject.toMap()); } //模糊查到的数据进行组装 return getQuestionAndAnswerList(searchList); } /** * 公共方法:批量—— in方法查询List数据 * @author shijing * @param ids id集合 * @param paramMap 其他参数 * @param columnName in字段列名 * @param collectionName 表名 * @return */ @Override public List<Map<String, Object>> batchSearchPageListByIds(List<String> ids, Map<String, Object> paramMap, String columnName, String collectionName) { List<Map<String,Object>> searchList = new ArrayList<>(); BasicDBObject query= new BasicDBObject(); //批量查询,in if (CollectionUtils.isNotEmpty(ids)){ BasicDBList values = new BasicDBList(); values.addAll(ids); query.put(columnName, new BasicDBObject("$in",values)); } //拼接参数 if(MapUtils.isNotEmpty(paramMap)){ for (String mapKey: paramMap.keySet()){ query.put(mapKey, paramMap.get(mapKey)); } } DBCursor dbCursor = mongoDao.findAll(query,collectionName); List<DBObject> list = dbCursor.toArray(); if (dbCursor!=null && dbCursor.size()>0){ for (DBObject dbObject: list){ searchList.add(dbObject.toMap()); } } return searchList; } /** * 公共方法:通过参数获取List数据 * @author shijing * @param paramMap 参数 * @param collectionName 表名 * @return */ @Override public List<Map<String, Object>> getListByParam(Map<String, Object> paramMap,String collectionName){ List<Map<String,Object>> searchList = new ArrayList<>(); BasicDBObject query= new BasicDBObject(); //拼接参数 if(MapUtils.isNotEmpty(paramMap)){ for (String mapKey: paramMap.keySet()){ query.put(mapKey, paramMap.get(mapKey)); } } DBCursor dbCursor = mongoDao.findAll(query,collectionName); List<DBObject> list = dbCursor.toArray(); if (dbCursor!=null && dbCursor.size()>0){ for (DBObject dbObject: list){ searchList.add(dbObject.toMap()); } } return searchList; } /** * 公共方法:通过参数获取Object数据 * @author shijing * @param paramMap * @param collectionName 表名 * @return */ @Override public Map<String, Object> getObjectByParam(Map<String, Object> paramMap, String collectionName) { Map<String,Object> webSiteInfo = new HashMap<>(); BasicDBObject query= new BasicDBObject(); //拼接参数 if(MapUtils.isNotEmpty(paramMap)){ for (String mapKey: paramMap.keySet()){ query.put(mapKey, paramMap.get(mapKey)); } } DBObject dbObject = mongoDao.findOne(query,collectionName); if(dbObject!=null){ return dbObject.toMap(); } return webSiteInfo; }注意事项:
mongodb模糊查询时
Pattern pattern = Pattern.compile("^.*" + param.get("keyword") +".*$"这种方式存在bug, 容易漏掉数据
应该使用下面这种方式:
query.put("page_html", Pattern.compile((String) param.get("keyword")));先记录到这吧,有需要在补充,批量in方法也在上述代码里面。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了Java操作MongoDB模糊查询和分页查询,供大家参考,具体内容如下模糊查询条件:1、完全匹配Patternpattern=Pattern
MongoDB查询操作的实例详解使用find或findOne进行查询。并可以进行范围查询、数据集查询、不等式查询,以及其他的一些查询。查询将会返回DBcurso
mongodb模糊查询并分页1.建立数据库代码如下:varmongoose=require('mongoose');varshortid=require('sh
1、问题描述:最近项目需要提供一个搜索框对多个字段进行模糊查询的操作代替下拉列表选择单个字段条件进行模糊查询的操作。2、解决办法:之前的四个条件的模糊查询代码A
前言模糊查询是数据库的基本操作之一,实现对给定的字符串是否与指定的模式进行匹配。如果字符完全匹配,可以用=等号表示,如果部分匹配可认为是一种模糊查询。在关系型数