当前位置: 首页 > news >正文

springBoot+mongoDB项目中,使用MongoFactory、MongoTemplate分页条件查询,增删查改

MongoDB:CRUD

    • 添加
    • 删除
    • 修改
    • 条件查询
    • 分页条件查询

只展示实现类代码

添加

@Autowiredprivate MongoTemplate mongoTemplate;@Autowiredprivate MongoFactory mongoFactory;@Overridepublic boolean saveEntity(entityForm form) {try {实体类 en = new 实体类();en.setName(form.getName);// ... 实体类 save = mongoTemplate.save(en);return Objects.nonNull(save.get_id());} catch (Exception e) {log.error(e.getMessage());}}

底下的就给关键代码了,w太懒了。。。

删除

            Query query = new Query(Criteria.where("条件字段名称例如_id").is(id));//id是传进来的条件DeleteResult remove = mongoTemplate.remove(query, 实体类.class);return remove.getDeletedCount() > 0; //返回删除条数

修改


Query query = new Query();// 添加修改表条件为id=id
query.addCriteria(Criteria.where("主键id字段名").is(id));Update update = new Update(); // 设置需要修改的字段update.set("字段名",新值);// 等等... //返回修改结果
UpdateResult updateResult = mongoTemplate.updateFirst(query, update, 实体类.class);
//updateResult.getModifiedCount()可以获得成功修改条数

条件查询

@Overridepublic List<实体类> getHbzbGudongList(条件实体类 search) {// 目前只有一个关键字字段(keywords) 可以添加多个Query query = new Query();if (Objects.nonNull(search.getKeywords())) {Pattern pattern = Pattern.compile("^.*" + search.getKeywords() + ".*$");query.addCriteria( // orOperator == 或者。里面俩条件关系是or,还有andOperator顾名思义等于数据库中的and new Criteria().orOperator( Criteria.where(条件字段名1).is(pattern),Criteria.where(条件字段名2).is(pattern)));}List<实体类> ls= mongoTemplate.find(query, 实体类.class);return ls;}

这玩意百度了好久用什么聚合查询 老是会报错什么的,导包也导不进,只能用底下发方法实现了

分页条件查询

private Integer type;private String keywords;-----------------上面是orderQuery 类的内容,可以自定义import org.springframework.*; //几乎包都在这下面,我懒得一个个复制出来了,别用*/*** 分页条件查询   //页码也可以不传,只要让orderQuery类继承一个基础分页对象就行* @param pageNum 页码* @param pageSize 条数* @param order 查询条件* @return 返回分页列表*/@Overridepublic Page<实体类> getOrderPage(Integer pageNum, Integer pageSize, orderQuery order) {Pageable pageable = PageRequest.of(pageNum - 1, pageSize);MongoTemplate mongoTemplate = mongoFactory.mongoTemplate("数据库名");Query query = new Query();// 判断条件类型if (Objects.nonNull(order.getType()) && Objects.nonNull(order.getKeywords())) {Integer type = order.getType();switch (type) { // 查询类型:{0:订单号,1:商家名称,2:商品名称}case 0 ->query.addCriteria("字段名1").is(order.getKeywords()));case 1 ->query.addCriteria("字段名2").is(order.getKeywords()));case 2 ->query.addCriteria("字段名3").is(order.getKeywords()));}}long total = mongoTemplate.count(query, 实体类.class);List<实体类> orderPageVOS = mongoTemplate.find(query.with(pageable), 实体类.class);return new PageImpl<>(orderPageVOS, pageable, total);}
http://www.lryc.cn/news/377961.html

相关文章:

  • Leetcode236 二叉树两节点的最近公共祖先
  • Web的UI自动化基础知识
  • 【我是产品经理_注册安全分析报告】
  • Java智慧工地源码 5G智慧工地系统源码 使用SAAS部署 三维可视化管理,与一线生产过程相融合,集成数据后台,统一前端入口,呈现多方项目信息;
  • lock_wait_timeout
  • 【可控图像生成系列论文(二)】MimicBrush 港大、阿里、蚂蚁集团合作论文解读2
  • Linux时间子系统6:NTP原理和Linux NTP校时机制
  • 边缘微型AI的宿主?—— RISC-V芯片
  • MySQL—navicat创建数据库表
  • html做一个画柱形图的软件
  • Pyshark——安装、解析pcap文件
  • java中的Random
  • PyMuPDF 操作手册 - 01 从PDF中提取文本
  • ResNet——Deep Residual Learning for Image Recognition(论文阅读)
  • java基础·小白入门(五)
  • 微观时空结构和虚数单位的关系
  • go-zero使用goctl生成mongodb的操作使用方法
  • 服务器新硬盘分区、格式化和挂载
  • Openldap集成Kerberos
  • (创新)基于VMD-CNN-BiLSTM的电力负荷预测—代码+数据
  • 机器 reboot 后 kubelet 目录凭空消失的灾难恢复
  • Pytorch构建vgg16模型
  • 分支结构相关
  • flutter开发实战-RichText富文本居中对齐
  • 智慧消防新篇章:可视化数据分析平台引领未来
  • u8g2 使用IIC驱动uc1617 lcd有时候某些像素显示不正确
  • 使用opencv合并两个图像
  • k8s学习笔记(一)
  • 自学前端——JavaScript篇
  • 高考毕业季--浅谈自己感想