MongoTemplate

配置:

<!--mongo-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

spring.data.mongodb.uri=mongodb://账号:密码@ip:端口/库名

查询

(1)查询全部=====db.集合名.find()
mongoTemplate.findAll(Class<T> entityClass, String collectionName) 
(2)查询符合条件中的第一条=====db.集合名.findOne(条件)
mongoTemplate.findOne(Query query, Class<T> entityClass, String collectionName)
(3)带条件查询=====db.集合名.find(条件)
mongoTemplate.find(Query query, Class<T> entityClass, String collectionName)
Query使用
1、创建一个query对象(用来封装所有条件对象),
     再创建一个criteria对象(用来构建条件)
2、精准条件:criteria.and(“key”).is(“条件”)
     模糊条件:criteria.and(“key”).regex(“条件”)
3、封装条件:query.addCriteria(criteria)
4、大于(创建新的criteria):Criteria gt = Criteria.where(“key”).gt(“条件”)
     小于(创建新的criteria):Criteria lt = Criteria.where(“key”).lt(“条件”)
5、Query.addCriteria(new Criteria().andOperator(gt,lt));
6、一个query中只能有一个andOperator()。其参数也可以是Criteria数组。
7、排序  :query.with(new Sort(Sort.Direction.ASC, "age"). and(new Sort(Sort.Direction.DESC, "date")))

新增

1、mongoTemplate.insert()-------------(MongoTemplate中)
2、mongoTemplate.save()--------------(MongoOperations中)
区别
insert: 若新增数据的主键已经存在,则会抛 org.springframework.dao.DuplicateKeyException 异常提示主键重复,不保存当前数据。
save: 若新增数据的主键已经存在,则会对当前已经存在的数据进行修改操作。
insert: 可以一次性插入一整个列表,而不用进行遍历操作,效率相对较高
save: 需要遍历列表,进行一个个的插入。

删除

mongoTemplate.remove(Query query,Class<T> entityClass)

修改

Update update = Update.update("要更新的字段", "更新的值");
1、方式一
mongoTemplate.upsert(query, update, Class<T> entityClass);
2、方式二
更新满足条件的第一条数据
mongoTemplate.updateFirst(query, update, Class<T> entityClass);
更新所有满足条件的数据
mongoTemplate.updateMulti(query, update, Class<T> entityClass);
区别
upsert:如果query条件没有筛选出对应的数据,那么upsert会插入一条新的数据。
update:如果query条件没有筛选出对应的数据,那么什么都不做。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值