admin
2024-04-09 3d28cc569ff9bdf20ac56598ae4de8e2809d6f35
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
package com.ruoyi.interchange.util;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.core.MongoTemplate;
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.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.List;
 
public abstract class MongoDbUtilService<T> {
        protected Logger logger = LoggerFactory.getLogger(MongoDbUtilService.class);
 
        /**
         * 反射获取泛型类型
         *
         * @return
         */
        protected abstract Class<T> getEntityClass();
 
        @Autowired
        private MongoTemplate mongoTemplate;
 
        /***
         * 保存一个对象
         * @param t
         */
        public int save(T t) {
            logger.info("-------------->MongoDB save start");
            this.mongoTemplate.save(t);
            return 1;
        }
 
        /***
         * 根据id从几何中查询对象
         * @param id
         * @return
         */
        public T queryById(String id) {
            Query query = new Query(Criteria.where("_id").is(id));
            logger.info("-------------->MongoDB find start");
            return this.mongoTemplate.findOne(query, this.getEntityClass());
        }
 
        /**
         * 根据条件查询集合
         *
         * @param object
         * @return
         */
        public List<T> queryList(T object) {
            Query query = getQueryByObject(object);
            logger.info("-------------->MongoDB find start");
            return mongoTemplate.find(query, this.getEntityClass());
        }
 
        /**
         * 根据条件查询只返回一个文档
         *
         * @param object
         * @return
         */
        public T queryOne(T object) {
            Query query = getQueryByObject(object);
            logger.info("-------------->MongoDB find start");
            return mongoTemplate.findOne(query, this.getEntityClass());
        }
 
        /***
         * 根据条件分页查询
         * @param object
         * @param start 查询起始值
         * @param size  查询大小
         * @return
         */
        public List<T> getPage(T object, int start, int size) {
            Query query = getQueryByObject(object);
            query.skip(start);
            query.limit(size);
            logger.info("-------------->MongoDB queryPage start");
            return this.mongoTemplate.find(query, this.getEntityClass());
        }
 
        /***
         * 根据条件查询库中符合条件的记录数量
         * @param object
         * @return
         */
        public Long getCount(T object) {
            Query query = getQueryByObject(object);
            logger.info("-------------->MongoDB Count start");
            return this.mongoTemplate.count(query, this.getEntityClass());
        }
 
        /***
         * 删除对象
         * @param t
         * @return
         */
        public int delete(T t) {
            logger.info("-------------->MongoDB delete start");
            return (int) this.mongoTemplate.remove(t).getDeletedCount();
        }
 
        /**
         * 根据id删除
         *
         * @param id
         */
        public void deleteById(String id) {
            Criteria criteria = Criteria.where("_id").is(id);
            if (null != criteria) {
                Query query = new Query(criteria);
                T obj = this.mongoTemplate.findOne(query, this.getEntityClass());
                logger.info("-------------->MongoDB deleteById start");
                if (obj != null) {
                    this.delete(obj);
                }
            }
        }
 
        /*MongoDB中更新操作分为三种
         * 1:updateFirst     修改第一条
         * 2:updateMulti     修改所有匹配的记录
         * 3:upsert  修改时如果不存在则进行添加操作
         * */
        /**
         * 修改匹配到的第一条记录
         * @param srcObj
         * @param targetObj
         */
        public void updateFirst(T srcObj, T targetObj){
            Query query = getQueryByObject(srcObj);
            Update update = getUpdateByObject(targetObj);
            logger.info("-------------->MongoDB updateFirst start");
            this.mongoTemplate.updateFirst(query,update,this.getEntityClass());
        }
 
        /***
         * 修改匹配到的所有记录
         * @param srcObj
         * @param targetObj
         */
        public void updateMulti(T srcObj, T targetObj){
            Query query = getQueryByObject(srcObj);
            Update update = getUpdateByObject(targetObj);
            logger.info("-------------->MongoDB updateFirst start");
            this.mongoTemplate.updateMulti(query,update,this.getEntityClass());
        }
 
        /***
         * 修改匹配到的记录,若不存在该记录则进行添加
         * @param srcObj
         * @param targetObj
         */
        public void updateInsert(T srcObj, T targetObj){
            Query query = getQueryByObject(srcObj);
            Update update = getUpdateByObject(targetObj);
            logger.info("-------------->MongoDB updateInsert start");
            this.mongoTemplate.upsert(query,update,this.getEntityClass());
        }
 
        /**
         * 将查询条件对象转换为query
         *
         * @param object
         * @return
         * @author Jason
         */
        public Query getQueryByObject(T object) {
            Query query = new Query();
            String[] fileds = getFiledName(object);
            Criteria criteria = new Criteria();
            for (int i = 0; i < fileds.length; i++) {
                String filedName = (String) fileds[i];
                Object filedValue = getFieldValueByName(filedName, object);
                if (filedValue != null) {
                    criteria.and(filedName).is(filedValue);
                }
            }
            query.addCriteria(criteria);
            return query;
        }
    /**
     * 将查询条件对象转换为query
     *
     * @param object
     * @return
     * @author Jason
     */
    public Query getQueryByObject2(T object,String sort) {
        Query query = new Query();
        String[] fileds = getFiledName(object);
        Criteria criteria = new Criteria();
        for (int i = 0; i < fileds.length; i++) {
            String filedName = (String) fileds[i];
            Object filedValue = getFieldValueByName(filedName, object);
            if (filedValue != null) {
                criteria.and(filedName).is(filedValue);
            }
        }
        query.with(Sort.by(Sort.Direction.DESC,sort));
        query.addCriteria(criteria);
        return query;
    }
 
        /**
         * 将查询条件对象转换为update
         *
         * @param object
         * @return
         * @author Jason
         */
        private Update getUpdateByObject(T object) {
            Update update = new Update();
            String[] fileds = getFiledName(object);
            for (int i = 0; i < fileds.length; i++) {
                String filedName = (String) fileds[i];
                Object filedValue =getFieldValueByName(filedName, object);
                if (filedValue != null) {
                    update.set(filedName, filedValue);
                }
            }
            return update;
        }
 
        /***
         * 获取对象属性返回字符串数组
         * @param o
         * @return
         */
        private static String[] getFiledName(Object o) {
            Field[] fields = o.getClass().getDeclaredFields();
            String[] fieldNames = new String[fields.length];
 
            for (int i = 0; i < fields.length; ++i) {
                fieldNames[i] = fields[i].getName();
            }
 
            return fieldNames;
        }
 
        /***
         * 根据属性获取对象属性值
         * @param fieldName
         * @param o
         * @return
         */
        private static Object getFieldValueByName(String fieldName, Object o) {
            try {
                String e = fieldName.substring(0, 1).toUpperCase();
                String getter = "get" + e + fieldName.substring(1);
                Method method = o.getClass().getMethod(getter, new Class[0]);
                return method.invoke(o, new Object[0]);
            } catch (Exception var6) {
                return null;
            }
        }
}