All Downloads are FREE. Search and download functionalities are using the official Maven repository.

me.wuwenbin.modules.mongodb.dao.MongoAccessor Maven / Gradle / Ivy

package me.wuwenbin.modules.mongodb.dao;

import com.mongodb.BasicDBList;
import com.mongodb.CommandResult;
import com.mongodb.WriteResult;
import me.wuwenbin.modules.mongodb.pojo.MongoStatic;
import me.wuwenbin.modules.mongodb.pojo.PageParam;
import me.wuwenbin.modules.mongodb.support.page.Page;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapreduce.GroupBy;
import org.springframework.data.mongodb.core.mapreduce.GroupByResults;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;

import java.util.*;
import java.util.regex.Pattern;

/**
 * Mongo数据库 dao操作类,基于spring-data-mongodb 1.10.1.RELEASE版本
 * 

* 官方文档:http://docs.spring.io/spring-data/data-mongo/docs/1.10.1.RELEASE/reference/html/ * 官方API:http://docs.spring.io/spring-data/data-mongo/docs/1.10.1.RELEASE/api/ *

* Created by wuwenbin on 2017/4/22. */ public abstract class MongoAccessor { protected static Logger LOG = LoggerFactory.getLogger(MongoAccessor.class); protected MongoTemplate mongoTemplate; public MongoAccessor(MongoTemplate mongoTemplate) { this.mongoTemplate = mongoTemplate; } /** * 获取分页分页信息 * * @param page * @return */ protected abstract PageParam getPageParam(Page page); /** * 获取mongoTemplate实例 * * @return */ public MongoTemplate getMongoTemplate() { return this.mongoTemplate; } /** * 查询满足条件的数目 * * @param query * @param clazz * @return */ public long findCountByQuery(Query query, Class clazz) { long count = mongoTemplate.count(query, clazz); LOG.info("- COUNT查询,结果数::" + count); return count; } /** * 通过query查询条件来查询Bean * * @param query * @param clazz * @param * @return */ public T findBeanByQuery(Query query, Class clazz) { LOG.info("- 查询Bean :" + (query != null ? query.toString() : "无条件查询")); return mongoTemplate.findOne(query, clazz); } /** * 根据mongodb 的object_id查询,不是我们自定义的id * * @param id * @param clazz * @param * @return */ public T findBeanById(Object id, Class clazz) { return mongoTemplate.findById(id, clazz); } /** * 根据MongoDB的主键ID查找Bean * * @param mongoId * @param clazz * @param * @return */ public T findBeanByMongoId(String mongoId, Class clazz) { Query query = new Query(Criteria.where(MongoStatic.MongoID).is(mongoId)); return findBeanByQuery(query, clazz); } /** * 正则表达式条件查找Bean * * @param fieldName * @param regex * @param clazz * @param * @return */ public T findBeanByRegxTxt(String fieldName, String regex, Class clazz) { Query query = new Query(Criteria.where(fieldName).regex(regex)); return findBeanByQuery(query, clazz); } /** * 正则表达式查找Bean * * @param fieldName * @param pattern * @param clazz * @param * @return */ public T findBeanByRegxPattern(String fieldName, Pattern pattern, Class clazz) { Query query = new Query(Criteria.where(fieldName).regex(pattern)); return findBeanByQuery(query, clazz); } /** * 根据某个字段来查找Bean,如果有多个此方法匹配的查询结果是返回第一条匹配的结果 * * @param fieldName * @param fieldValue * @param clazz * @return */ public T findBeanByField(String fieldName, Object fieldValue, Class clazz) { Query query = new Query(Criteria.where(fieldName).is(fieldValue)); return findBeanByQuery(query, clazz); } /** * 根据多列数据来查询bean * * @param fieldMap * @param clazz * @param * @return */ public T findBeanByFields(TreeMap fieldMap, Class clazz) { if (fieldMap == null || fieldMap.isEmpty() || fieldMap.size() == 0) { return null; } else if (fieldMap.size() == 1) { Iterator> iterator = fieldMap.entrySet().iterator(); Map.Entry entry = iterator.next(); return findBeanByField(entry.getKey(), entry.getValue(), clazz); } else { Iterator> iterator = fieldMap.entrySet().iterator(); Map.Entry entry = iterator.next(); Criteria criteria = Criteria.where(entry.getKey()).is(entry.getValue()); while (iterator.hasNext()) { Map.Entry entry2 = iterator.next(); criteria.and(entry2.getKey().toString()).is(entry2.getValue()); } Query query = new Query(criteria); return findBeanByQuery(query, clazz); } } /** * 通过query查询出bean集合 * * @param query * @param clazz * @param * @return */ public List findListBeanByQuery(Query query, Class clazz) { LOG.info("- 查询ListBean :" + (query != null ? query.toString() : "没有查询条件")); return mongoTemplate.find(query, clazz); } /** * 查找所有Bean * * @param clazz * @param * @return */ public List findListBean(Class clazz) { return findListBeanByQuery(null, clazz); } /** * 查询排序集合ListBean * * @param sortField * @param direction * @param clazz * @param * @return */ public List findListBeanBySort(String sortField, Sort.Direction direction, Class clazz) { Query query = new Query().with(new Sort(direction, sortField)); LOG.info("- 查询Bean :" + (query != null ? query.toString() : "无条件查询")); return mongoTemplate.find(query, clazz); } /** * 根据某个字段查询符合的ListBean * * @param fieldName * @param fieldValue * @param clazz * @param * @return */ public List findListBeanByField(String fieldName, Object fieldValue, Class clazz) { Query query = new Query(Criteria.where(fieldName).is(fieldValue)); return findListBeanByQuery(query, clazz); } /** * 根据多列数据来查询ListBean * * @param fieldMap * @param clazz * @param * @return */ public List findListBeanByFields(TreeMap fieldMap, Class clazz) { if (fieldMap == null || fieldMap.isEmpty() || fieldMap.size() == 0) { return null; } else if (fieldMap.size() == 1) { Iterator> iterator = fieldMap.entrySet().iterator(); Map.Entry entry = iterator.next(); return findListBeanByField(entry.getKey(), entry.getValue(), clazz); } else { Iterator> iterator = fieldMap.entrySet().iterator(); Map.Entry entry = iterator.next(); Criteria criteria = Criteria.where(entry.getKey()).is(entry.getValue()); while (iterator.hasNext()) { Map.Entry entry2 = iterator.next(); criteria.and(entry2.getKey().toString()).is(entry2.getValue()); } Query query = new Query(criteria); return findListBeanByQuery(query, clazz); } } /** * 此方法默认是查找count(*) 和 用户定义的相关字段groupByFields 查询的结果类似 * [{"name" : "智慧百年" , "count" : 1} , { "name" : "百年建设" , "count" :2}] * 这种集合list
* * @param criteria * @param clazz * @param groupByFields * @param * @return */ public List findListMapByCriteriaWithGroupBy(Criteria criteria, Class clazz, String... groupByFields) { String inputCollectionName = clazz.getAnnotation(Document.class).collection(); GroupBy groupBy = GroupBy.key(groupByFields).initialDocument("{count:0}").reduceFunction("function(doc, prev){prev.count+=1}"); GroupByResults groupByResults = mongoTemplate.group(criteria, inputCollectionName, groupBy, clazz); BasicDBList list = (BasicDBList) groupByResults.getRawResults().get(MongoStatic.RAW_RESULT); LOG.info("- GroupBy查询,返回list集合 :" + list); return list; } /** * 类似于select distinct [column] from table,输出结果类似 ["结果1" , "结果2"]
* * @param key * @param clazz * @param * @return */ public List findListWithDistinct(String key, Class clazz) { String collectionName = clazz.getAnnotation(Document.class).collection(); CommandResult result = mongoTemplate.executeCommand("{distinct:'" + collectionName + "', key:'" + key + "'}"); BasicDBList list = (BasicDBList) result.get("values"); LOG.info("- Distinct查询,返回list集合 :" + list); return list; } /** * 类似于select distinct [column] from table,输出结果类似 ["结果1" , "结果2"]
* * @param key * @param collectionName * @return */ public List findListWithDistinct(String key, String collectionName) { CommandResult result = mongoTemplate.executeCommand("{distinct:'" + collectionName + "', key:'" + key + "'}"); BasicDBList list = (BasicDBList) result.get("values"); LOG.info("- Distinct查询,返回list集合 :" + list); return list; } /** * 执行js * * @param json * @return */ public CommandResult runCommand(String json) { LOG.info("- 执行JSON :" + json.toString()); return mongoTemplate.executeCommand(json); } /** * 根据Update条件更新数据 * * @param query * @param update * @param clazz * @return */ public int update(Query query, Update update, Class clazz) { WriteResult writeResult = mongoTemplate.updateMulti(query, update, clazz); int n = writeResult.getN(); LOG.info("- 更新所有匹配文档集合 ,满足的更新条数:" + n); return n; } /** * 根据某个条件更新所有符合条件的某些字段 * * @param filedName * @param filedValue * @param fieldMap * @param clazz * @return */ public int updateAllByField(String filedName, Object filedValue, TreeMap fieldMap, Class clazz) { Query query = new Query(Criteria.where(filedName).is(filedValue)); Update update = new Update(); Iterator> iterator = fieldMap.entrySet().iterator(); while (iterator.hasNext()) { Map.Entry entry = iterator.next(); update.set(entry.getKey(), entry.getValue()); } return update(query, update, clazz); } /** * 根据id更新某些符合条件的数据字段 * * @param idVal * @param fieldMap * @param clazz * @return */ public int updateAllById(String idVal, TreeMap fieldMap, Class clazz) { return updateAllByField(MongoStatic.MongoID, idVal, fieldMap, clazz); } /** * 根据某个条件更新某个符合条件的数据字段vv * * @param condName * @param condVal * @param fieldName * @param fieldVlaue * @param clazz * @return */ public int updateAllByField(String condName, Object condVal, String fieldName, Object fieldVlaue, Class clazz) { Query query = new Query(Criteria.where(condName).is(condVal)); Update update = new Update().set(fieldName, fieldVlaue); return update(query, update, clazz); } /** * 根据id条件更新某个符合条件的数据字段 * * @param id * @param fieldName * @param fieldVlaue * @param clazz * @return */ public int updateAllById(String id, String fieldName, Object fieldVlaue, Class clazz) { Query query = new Query(Criteria.where(MongoStatic.MongoID).is(id)); Update update = new Update().set(fieldName, fieldVlaue); return update(query, update, clazz); } /** * 插入多个文档 * * @param objectsToSave * @param */ public void insertAll(Collection objectsToSave) { LOG.info("- 插入多个文档"); mongoTemplate.insertAll(objectsToSave); } /** * 插入一条bean * * @param insertBean */ public void insert(Object insertBean) { LOG.info("- 插入数据 :" + insertBean); mongoTemplate.insert(insertBean); } /** * 删除指定的collection名 * * @param collectionName */ public void dropCollectionByName(String collectionName) { LOG.info("- 删除文档,根据collection的名字"); mongoTemplate.dropCollection(collectionName); } /** * 更具查询条件删除对应数据库中对应的文档中的实体类 * * @param query * @param clazz * @param * @return */ public int removeBeanByQueryAndClass(Query query, Class clazz) { WriteResult writeResult = mongoTemplate.remove(query, clazz); int N = writeResult.getN(); LOG.info("- 删除文档[" + clazz.getAnnotation(Document.class).collection() + "],返回成功删除数 :" + N); return N; } /** * 无查询条件删除某个实体类在数据库中对应的,如果实体类上@Document指定collection,则值删除指定的collection的数据 * * @param removeBean * @return */ public int removeBean(Object removeBean) { WriteResult writeResult = mongoTemplate.remove(removeBean); int n = writeResult.getN(); LOG.info("- 删除所有匹配文档集合 ,满足的删除条数:" + n); return n; } /** * 删除数据库中指定文档中的相对应的实体类的数据 * * @param query * @param collectionName * @return */ public int removeBeanByQueryAndCollectionName(Query query, String collectionName) { WriteResult writeResult = mongoTemplate.remove(query, collectionName); int n = writeResult.getN(); LOG.info("- 删除所有匹配文档集合 ,满足的删除条数:" + n); return n; } /** * 删除数据库中指定文档中的相对应的实体类的数据 * * @param removeBean * @param collectionName * @return */ public int removeBeanByBeanAndCollectionName(Object removeBean, String collectionName) { WriteResult writeResult = mongoTemplate.remove(removeBean, collectionName); int n = writeResult.getN(); LOG.info("- 删除所有匹配文档集合 ,满足的删除条数:" + n); return n; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy