项目里MongodbTemplate用法

1. 先引入依赖(这里以gradle项目为例)

java 复制代码
implementation 'org.springframework.boot:spring-boot-starter-data-mongodb'

2. 在对应应类上获取MongoTemplate

java 复制代码
 private final MongoTemplate mongoTemplate;

3. 下面就是一些常用功能实现

注: 下面的XXX是你的表名

3.1 数据保存

实现1 : 基本数据插入方式1:

java 复制代码
Map<String, Object> map = new HashMap();
map.put("name","test");
Document document = new Document();
document.putAll(map);
Document insert = mongoTemplate.insert(document, XXX);
// 如果需要获取保存后的数据的主键id,则进行下面的操作
String childId = insert.get(MongoKeyConstants.PRIMARY_KEY).toString();

基本数据插入方式2:

java 复制代码
Document doc = new Document();
doc.put("name", "狮子狗");
mongoTemplate.insert(doc, licenseAllocation);

3.2 数据查询
查询一条:

举个栗子: 查询用户名为光头强的数据

java 复制代码
Query query = new Query();
query.addCriteria(Criteria.where("username").is("光头强"));
Document doc = mongoTemplate.findOne(query, Document.class, XXX);

查询多条:

注: 查询后的主键id返回的是一个object对象,所以需要处理一下

java 复制代码
Query query = new Query();
query.addCriteria(Criteria.where("username").is("光头强"));
List<Document> dataList = mongoTemplate.find(query, Document.class, XXX);
// Constants.PRIMARY_KEY 值为  "_id"
dataList.forEach(document -> {
	document.put(MongoKeyConstants.PRIMARY_KEY, t.get(Constants.PRIMARY_KEY).toString());
});

查询条件3: 根据cinInfoId,开始时间和结束时间,以及xx名称模糊查询,进行筛选

注: 1. Constants 里的都是表里的字段

  1. 这里的开始时间和结束时间都是可以单选的,所以需要分开判断
java 复制代码
Query query = new Query();
 query.addCriteria(Criteria.where(MongoKeyConstants.CI_INFO_ID).is(cinInfoId));
 if (searchForm.getUpdateBy() != null) {
     query.addCriteria(Criteria.where(Constants.UPDATED_BY).is(searchForm.getUpdateBy()));
 }
 Date updateStart = searchForm.getUpdateStart();
 Date updateEnd = searchForm.getUpdateEnd();
 if (Objects.nonNull(updateStart) && Objects.nonNull(updateEnd)) {
     query.addCriteria(Criteria.where(Constants.UPDATED_AT).gte(updateStart).lte(updateEnd));
 } else {
     if (updateStart != null) {
         query.addCriteria(Criteria.where(Constants.UPDATED_AT).gte(updateStart));
     }
     if (updateEnd != null) {
         query.addCriteria(Criteria.where(Constants.UPDATED_AT).lte(updateEnd));
     }
 }

 //根据字段名模糊查询
 String updateFieldName = searchForm.getUpdateFieldName();
 if (StringUtils.isNotBlank(updateFieldName)) {
     query.addCriteria(Criteria.where(Constants.CHANGE_CONTENT).elemMatch(Criteria.where("fieldName").is(updateFieldName)));
 }
 //查询
 List<Document> documents = mongoTemplate.find(query, Document.class, XXX);
相关推荐
掘金-我是哪吒11 分钟前
分布式微服务系统架构第157集:JavaPlus技术文档平台日更-Java多线程编程技巧
java·分布式·微服务·云原生·架构
飞翔的佩奇20 分钟前
Java项目:基于SSM框架实现的忘忧小区物业管理系统【ssm+B/S架构+源码+数据库+毕业论文+开题报告】
java·数据库·mysql·vue·毕业设计·ssm框架·小区物业管理系统
RainbowSea37 分钟前
跨域问题(Allow CORS)解决(3 种方法)
java·spring boot·后端
掘金-我是哪吒38 分钟前
分布式微服务系统架构第155集:JavaPlus技术文档平台日更-Java线程池实现原理
java·分布式·微服务·云原生·架构
RainbowSea41 分钟前
问题 1:MyBatis-plus-3.5.9 的分页功能修复
java·spring boot·mybatis
前端 贾公子1 小时前
monorepo + Turborepo --- 开发应用程序
java·前端·javascript
不学会Ⅳ1 小时前
Mac M芯片搭建jdk源码环境(jdk24)
java·开发语言·macos
虫小宝1 小时前
高佣金返利平台监控体系建设:APM、链路追踪与佣金异常预警系统技术实现
java
sniper_fandc2 小时前
SpringBoot系列—入门
java·spring boot·后端
代码的余温3 小时前
Maven引入第三方JAR包实战指南
java·maven·jar