BaseMongoDaoImpl实现类抽取

BaseMongoDaoImpl实现类

import com.zh.cloud.common.data.entity.GridRequest;
import com.zh.cloud.common.data.entity.OrderCondition;
import com.zh.cloud.common.data.entity.WhereCondition;
import com.zh.cloud.common.data.entity.entityMenu.OrderConditionMethod;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Sort;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.mongodb.core.MongoTemplate;
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 com.zh.cloud.common.data.entity.entityMenu.WhereConditionMethod;


import javax.annotation.PostConstruct;
import java.lang.reflect.ParameterizedType;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern;

/**
 * 抽取出来的BaseMongoDaoImpl
 * @author tianxiaobin
 *
 */
public class BaseMongoDaoImpl<T> implements  BaseMongoDaoI<T>{

    public static BaseMongoDaoImpl mongodbUtils;
    public Class c;
    @PostConstruct
    public void init() {
        mongodbUtils = this;
        mongodbUtils.mongoTemplate = this.mongoTemplate;
        c= (Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
    }

    @Autowired
    private MongoTemplate mongoTemplate;

    /**
     * 保存数据对象,集合为数据对象中@Document 注解所配置的collection
     *
     * @param obj
     *            数据对象
     */
    @Override
    public void save(T obj) {
        mongodbUtils.mongoTemplate.save(obj);
    }

    /**
     * 指定集合保存数据对象
     *
     * @param obj
     *            数据对象
     * @param collectionName
     *            集合名
     */
    @Override
    public void save(T obj, String collectionName) {
        mongodbUtils.mongoTemplate.save(obj, collectionName);
    }

    /**
     * 根据数据对象中的id删除数据,集合为数据对象中@Document 注解所配置的collection
     *
     * @param obj
     *            数据对象
     */
    @Override
    public void remove(T obj) {

        mongodbUtils.mongoTemplate.remove(obj);
    }

    /**
     * 指定集合 根据数据对象中的id删除数据
     *
     * @param obj
     *            数据对象
     * @param collectionName
     *            集合名
     */
    @Override
    public void remove(T obj, String collectionName) {

        mongodbUtils.mongoTemplate.remove(obj, collectionName);
    }

    /**
     * 根据key,value到指定集合删除数据
     *
     * @param key
     *            键
     * @param value
     *            值
     * @param collectionName
     *            集合名
     */
    @Override
    public void removeById(String key, Object value, String collectionName) {
        Criteria criteria = Criteria.where(key).is(value);
        criteria.and(key).is(value);
        Query query = Query.query(criteria);
        mongodbUtils.mongoTemplate.remove(query, collectionName);
    }

    /**
     * 指定集合 修改数据,且仅修改找到的第一条数据
     *
     * @param accordingKey
     *            修改条件 key
     * @param accordingValue
     *            修改条件 value
     * @param updateKeys
     *            修改内容 key数组
     * @param updateValues
     *            修改内容 value数组
     * @param collectionName
     *            集合名
     */
    @Override
    public void updateFirst(String accordingKey, Object accordingValue, String[] updateKeys, Object[] updateValues,
                                   String collectionName) {

        Criteria criteria = Criteria.where(accordingKey).is(accordingValue);
        Query query = Query.query(criteria);
        Update update = new Update();
        for (int i = 0; i < updateKeys.length; i++) {
            update.set(updateKeys[i], updateValues[i]);
        }
        mongodbUtils.mongoTemplate.updateFirst(query, update, collectionName);
    }

    /**
     * 指定集合 修改数据,且修改所找到的所有数据
     *
     * @param accordingKey
     *            修改条件 key
     * @param accordingValue
     *            修改条件 value
     * @param updateKeys
     *            修改内容 key数组
     * @param updateValues
     *            修改内容 value数组
     * @param collectionName
     *            集合名
     */
    @Override
    public void updateMulti(String accordingKey, Object accordingValue, String[] updateKeys, Object[] updateValues,
                                   String collectionName) {

        Criteria criteria = Criteria.where(accordingKey).is(accordingValue);
        Query query = Query.query(criteria);
        Update update = new Update();
        for (int i = 0; i < updateKeys.length; i++) {
            update.set(updateKeys[i], updateValues[i]);
        }
        mongodbUtils.mongoTemplate.updateMulti(query, update, collectionName);
    }

    /**
     * 根据条件查询出所有结果集 集合为数据对象中@Document 注解所配置的collection
     *
     * @param obj
     *            数据对象
     * @param findKeys
     *            查询条件 key
     * @param findValues
     *            查询条件 value
     * @return
     */
    @Override
    public List<T> find(T obj, String[] findKeys, Object[] findValues) {
        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).is(findValues[i]);
            } else {
                criteria.and(findKeys[i]).is(findValues[i]);
            }
        }
        Query query = Query.query(criteria);
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c);
        return resultList;
    }

    /**
     * 指定集合 根据条件查询出所有结果集
     *
     * @param obj
     *            数据对象
     * @param findKeys
     *            查询条件 key
     * @param findValues
     *            查询条件 value
     * @param collectionName
     *            集合名
     * @return
     */
    @Override
    public List<T> find(T obj, String[] findKeys, Object[] findValues, String collectionName) {

        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).is(findValues[i]);
            } else {
                criteria.and(findKeys[i]).is(findValues[i]);
            }
        }
        Query query = Query.query(criteria);
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c, collectionName);
        return resultList;
    }

    /**
     * 指定集合 分组查询结果
     *
     * @param obj
     *            数据对象
     * @param groupBy
     *            排序对象
     * @param collectionName
     *            集合名
     * @return
     *
     */
    @Override
    public List<T> group(String collectionName, GroupBy groupBy, T obj){
        //TODO groupBy的例子:根据carId和CarLicenseNO分组 , 求出分组数量
        // GroupBy groupBy = GroupBy.key("carId","CarLicenseNO").initialDocument("{carCount:0}")
        // .reduceFunction("function(key, values){values.carCount+=1;}");
        GroupByResults<T> group = mongodbUtils.mongoTemplate.group(collectionName, groupBy, c);
        List<T> tList = (List)group.getRawResults().get("retval");
        return tList;
    }

    /**
     * 指定集合 根据条件查询出所有结果集 并排倒序
     *
     * @param obj
     *            数据对象
     * @param findKeys
     *            查询条件 key
     * @param findValues
     *            查询条件 value
     * @param collectionName
     *            集合名
     * @param sort
     *            排序字段
     * @return
     */
    @Override
    public List<T> find(T obj, String[] findKeys, Object[] findValues, String collectionName ,String sort) {
        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).is(findValues[i]);
            } else {
                criteria.and(findKeys[i]).is(findValues[i]);
            }
        }
        Query query = Query.query(criteria);
        query.with(new Sort(Direction.DESC, sort));
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c, collectionName);
        return resultList;
    }

    /**
     * 根据条件查询出符合的第一条数据 集合为数据对象中 @Document 注解所配置的collection
     *
     * @param obj
     *            数据对象
     * @param findKeys
     *            查询条件 key
     * @param findValues
     *            查询条件 value
     * @return
     */
    @Override
    public T findOne(T obj, String[] findKeys, Object[] findValues) {
        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).is(findValues[i]);
            } else {
                criteria.and(findKeys[i]).is(findValues[i]);
            }
        }
        Query query = Query.query(criteria);
        T resultObj = (T)mongodbUtils.mongoTemplate.findOne(query, c);
        return resultObj;
    }

    /**
     * 指定集合 根据条件查询出符合的第一条数据
     *
     * @param obj
     *            数据对象
     * @param findKeys
     *            查询条件 key
     * @param findValues
     *            查询条件 value
     * @param collectionName
     *            集合名
     * @return
     */
    @Override
    public T findOne(T obj, String[] findKeys, Object[] findValues, String collectionName) {
        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).is(findValues[i]);
            } else {
                criteria.and(findKeys[i]).is(findValues[i]);
            }
        }
        Query query = Query.query(criteria);
        T resultObj = (T)mongodbUtils.mongoTemplate.findOne(query, c, collectionName);
        return resultObj;
    }

    /**
     * 查询出所有结果集 集合为数据对象中 @Document 注解所配置的collection
     *            数据对象
     * @return
     */
    @Override
    public List<T> findAll(T obj) {
        List<T> resultList = mongodbUtils.mongoTemplate.findAll(c);
        return resultList;
    }

    /**
     * 指定集合 查询出所有结果集
     *
     * @param obj
     *            数据对象
     * @param collectionName
     *            集合名
     * @return
     */
    @Override
    public List<T> findAll(T obj, String collectionName) {
        List<T> resultList = mongodbUtils.mongoTemplate.findAll(c, collectionName);
        return resultList;
    }

    /**
     * 分页查询所有数据
     * @param obj
     * @param sort
     * @param pageIndex
     * @param pageCount
     * @return
     */
    @Override
    public List<T> findAllByPage(T obj,String sort, int pageIndex, int pageCount) {
        Query query = new Query().skip(pageIndex * pageCount).limit(pageCount).with(new Sort(Direction.DESC, sort));
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c);
        return resultList;
    }

    @Override
    public long getCount(T obj) {
        Query query = new Query();
        return mongodbUtils.mongoTemplate.count(query, c);
    }

    @Override
    public long getCount(T obj, String sort, GridRequest gridRequest) {
        int pageIndex = 1;
        int pageCount = 10;
        List<WhereCondition> whereConditions = null;
        List<OrderCondition> orderConditions = null;
        if(gridRequest != null){
            //接收页面页码
            pageIndex = gridRequest.getPageIndex();
            //接收页面显示数量
            pageCount = gridRequest.getPageItemCount();
            //接收筛选条件
            whereConditions = gridRequest.getWhereConditions();
            //接收排序条件
            orderConditions = gridRequest.getOrderConditions();
        }
        Query query = new Query();
        if(whereConditions!=null && !whereConditions.isEmpty()){
            for (WhereCondition whereCondition : whereConditions) {
                if(StringUtils.isNotBlank(whereCondition.getValue().toString())){
                    if (whereCondition.getMethod().equals(WhereConditionMethod.Like)){
                        Pattern pattern = Pattern.compile("^.*"+whereCondition.getValue()+".*$", Pattern.CASE_INSENSITIVE);
                        query.addCriteria(Criteria.where(whereCondition.getField()).regex(pattern));
                    }else if (whereCondition.getMethod().equals(WhereConditionMethod.LessThanEqual)){
                        System.out.println(whereCondition.getField()+whereCondition.getValue()+whereCondition.getMethod());
                        query.addCriteria(Criteria.where(whereCondition.getField()).lt(whereCondition.getValue()));
                    }else if(whereCondition.getMethod().equals(WhereConditionMethod.GreaterThanEqual)){
                        query.addCriteria(Criteria.where(whereCondition.getField()).gte(whereCondition.getValue()));
                    }
                }
            }
        }
        ArrayList<Sort.Order> orders = new ArrayList<>();
        Sort.Order field = null;
        if(orderConditions!=null && !orderConditions.isEmpty()){
            for (OrderCondition orderCondition : orderConditions) {
                if(orderCondition.getMethod().equals(OrderConditionMethod.DESC) && StringUtils.isNotBlank(orderCondition.getField())){
                    field = Sort.Order.desc(orderCondition.getField());
                }else if(orderCondition.getMethod().equals(OrderConditionMethod.ASC) && StringUtils.isNotBlank(orderCondition.getField())){
                    field = Sort.Order.asc(orderCondition.getField());
                }
                orders.add(field);
            }
        }
        query.skip(pageIndex-1 * pageCount).limit(pageCount);
        query.with(Sort.by(orders
        ));
        return mongodbUtils.mongoTemplate.count(query, c);
    }

    @Override
    public List<T> find(T obj, String sort, GridRequest gridRequest){
        int pageIndex = 1;
        int pageCount = 10;
        List<WhereCondition> whereConditions = null;
        List<OrderCondition> orderConditions = null;
        if(gridRequest != null){
            //接收页面页码
            pageIndex = gridRequest.getPageIndex();
            //接收页面显示数量
            pageCount = gridRequest.getPageItemCount();
            //接收筛选条件
            whereConditions = gridRequest.getWhereConditions();
            //接收排序条件
            orderConditions = gridRequest.getOrderConditions();
        }
        Query query = new Query();
        if(whereConditions!=null && !whereConditions.isEmpty()){
            for (WhereCondition whereCondition : whereConditions) {
                if(StringUtils.isNotBlank(whereCondition.getValue().toString())){
                    if (whereCondition.getMethod().equals(WhereConditionMethod.Like)){
                        Pattern pattern = Pattern.compile("^.*"+whereCondition.getValue()+".*$", Pattern.CASE_INSENSITIVE);
                        query.addCriteria(Criteria.where(whereCondition.getField()).regex(pattern));
                    }else if(whereCondition.getMethod().equals(WhereConditionMethod.Equal)){
                        query.addCriteria(Criteria.where(whereCondition.getField()).is(whereCondition.getValue()));
                    }
                    else if (whereCondition.getMethod().equals(WhereConditionMethod.LessThanEqual)){
                        System.out.println(whereCondition.getField()+whereCondition.getValue()+whereCondition.getMethod());
                        query.addCriteria(Criteria.where(whereCondition.getField()).lt(whereCondition.getValue()));
                    }else if(whereCondition.getMethod().equals(WhereConditionMethod.GreaterThanEqual)){
                        query.addCriteria(Criteria.where(whereCondition.getField()).gte(whereCondition.getValue()));
                    }
                }
            }
        }
        ArrayList<Sort.Order> orders = new ArrayList<>();
        Sort.Order field = null;
        if(orderConditions!=null && !orderConditions.isEmpty()){
            for (OrderCondition orderCondition : orderConditions) {
                if(orderCondition.getMethod().equals(OrderConditionMethod.DESC) && StringUtils.isNotBlank(orderCondition.getField())){
                    field = Sort.Order.desc(orderCondition.getField());
                }else if(orderCondition.getMethod().equals(OrderConditionMethod.ASC) && StringUtils.isNotBlank(orderCondition.getField())){
                    field = Sort.Order.asc(orderCondition.getField());
                }
                orders.add(field);
            }
        }
        query.skip(pageIndex * pageCount).limit(pageCount);
        query.with(Sort.by(orders
        ));
//                Sort.Order.desc("carLicenseNO"),
//                Sort.Order.desc("startTime")
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c);
        //long count = mongodbUtils.mongoTemplate.count(query, c);
        return resultList;
    }

    @Override
    public List<T> findLike(T obj, String[] findKeys, Object[] findValues) {
        Criteria criteria = null;
        for (int i = 0; i < findKeys.length; i++) {
            if (i == 0) {
                criteria = Criteria.where(findKeys[i]).regex(".*?\\" +findValues[i]+ ".*");
            } else {
                criteria.and(findKeys[i]).regex(".*?\\" +findValues[i]+ ".*");
            }
        }
        Query query = Query.query(criteria);
        List<T> resultList = mongodbUtils.mongoTemplate.find(query, c);
        return resultList;
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aloneii

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值