mongoTemplate根据id模糊分页条件查询

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: mongoTemplate根据id模糊分页条件查询
package com.liupei.controller;
 
import com.liupei.entity.Fruit;
import com.liupei.entity.User;
import com.mongodb.WriteResult;
import com.mongodb.client.result.DeleteResult;
import com.mongodb.client.result.UpdateResult;
import org.bson.Document;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
import org.springframework.data.domain.ExampleMatcher;
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 org.springframework.web.bind.annotation.*;
 
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Pattern;
 
/**
 * TODO
 *
 * @author liu pei
 * @version 1.0
 * @mail 3268727800@qq.com
 * @date 2020/11/17 22:07
 */
@RestController
@RequestMapping("/user")
public class UserController {
 
    @Autowired
    private MongoTemplate mongoTemplate;
 
    /**
     * 单属性保存
     * @param user
     * @return
     */
    @RequestMapping("/save")
    public Object save(@RequestBody User user) {
        return mongoTemplate.save(user);
    }
 
    /**
     * 多属性保存
     * @param fruit
     * @return
     */
    @RequestMapping("/save/attr")
    public Object saveAttr(@RequestBody Fruit fruit) {
        return mongoTemplate.save(fruit);
    }
 
    /**
     * 根据姓名查询
     * @param name
     * @return
     */
    @GetMapping(value = "/test2")
    public User findTestByName(@RequestParam(value = "name") String name) {
        Query query = new Query(Criteria.where("name").is(name));
        User user = mongoTemplate.findOne(query, User.class);
        return user;
 
    }
 
    /**
     *  使用in模糊查询类似于SQL中的IN
     * 多属性查询:根据名称查询
     * @param colo
     * @return
     */
    @GetMapping(value = "/colo")
    public Object findByColoer(@RequestParam(value = "colo") String colo) {
        Query query = new Query(Criteria.where("attr.name").in(colo));
        List<Fruit> fruits = mongoTemplate.find(query, Fruit.class);
        return fruits;
 
    }
    /**
     * all
     * 多属性查询:根据名称查询
     * @param colo
     * @return
     */
    @GetMapping(value = "/colo/all")
    public Object findByColoerAll(@RequestParam(value = "colo") String colo) {
 
        Query query = new Query(Criteria.where("attr.name").all(colo));
        List<Fruit> fruitList = mongoTemplate.find(query, Fruit.class);
        return fruitList;
 
    }
 
    /**
     * 根据id查询
     * @param id
     * @return
     */
    @GetMapping(value = "/find/id")
    public User findById(@RequestParam(value = "id") String id) {
        Query query = new Query(Criteria.where("_id").is(id));
        User byId = mongoTemplate.findById(query, User.class);
        return byId;
    }
 
    /**
     * 根据id删除
     * @param id
     * @return
     */
    @GetMapping(value = "/del/id")
    public Object del(@RequestParam(value = "id") String id) {
        Query query = new Query(Criteria.where("_id").is(id));
        DeleteResult remove = mongoTemplate.remove(query, User.class);
        return remove;
    }
 
    /**
     *  更新实体
     * @param user
     * @return
     */
    @RequestMapping("/update")
    public Object update(@RequestBody User user) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(user.getId()));
 
        Document doc = new Document();
        mongoTemplate.getConverter().write(user,doc);
 
        Update update = Update.fromDocument(doc, "_id");
 
        UpdateResult updateResult = mongoTemplate.upsert(query, update, User.class);
 
        return mongoTemplate.save(updateResult);
    }
 
    /**
     *  更新某个属性
     * @param user
     * @return
     */
    @RequestMapping("/update/atrr")
    public Object updateAttr(@RequestBody User user) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(user.getId()));  //_id区分引号 "1"和1
        Update update = Update.update("name", user.getName());
 
//    WriteResult upsert = mongoTemplate.updateMulti(query, update, "userList"); //查询到的全部更新
//    WriteResult upsert = mongoTemplate.updateFirst(query, update, "userList"); //查询更新第一条
 
        UpdateResult upsert = mongoTemplate.upsert(query, update, User.class);//有则更新,没有则新增
 
        //返回执行的条数
        return upsert;
    }
 
 
    /**
     * 根据名字模糊查询
     * @param name
     * @return
     */
    @GetMapping(value = "/find/name/page")
    public Object findByNamePage(@RequestParam(value = "name") String name) {
        Query query = new Query();
        Criteria criteria = new Criteria();
 
 
        Pattern pattern = Pattern.compile("^.*"+name+".*$", Pattern.CASE_INSENSITIVE);
        //姓名模糊检索
        query.addCriteria(criteria.where("name").regex(pattern));
        //模糊查询名字
        List<User> users = mongoTemplate.find(query, User.class);
        return users;
    }
 
    /**
     * 多条件:根据名字模糊查询,年龄6-18
     * @param name
     * @return
     */
    @GetMapping(value = "/find/like/page")
    public Object findByNameAgePage(@RequestParam(value = "name") String name) {
        Query query = new Query();
        Criteria criteria = new Criteria();
 
        //年龄 6-18
        query.addCriteria(criteria.where("age").gte(6).lte(18));
        //姓名模糊检索
        query.addCriteria(criteria.where("name").regex(name));
        //模糊查询名字
        List<User> users = mongoTemplate.find(query, User.class);
        return users;
    }
 
 
    @GetMapping(value = "/page")
    public Object page(@RequestParam(value = "name") String name) {
        Map<String, Object> resultMap = new HashMap<>();
 
        Query query = new Query();
        Criteria criteria = new Criteria();
        Pattern pattern = Pattern.compile("^.*"+name+".*$", Pattern.CASE_INSENSITIVE);
        //姓名模糊检索
        query.addCriteria(criteria.where("name").regex(pattern));
 
        int totalCount = (int)mongoTemplate.count(query, User.class);
 
        int currentPage = 0;
        // 设置查询条数
        int pageSize = 10;
        // 设置起始数
        query.skip((currentPage - 1) * pageSize).limit(pageSize);
 
        // 数据总页数
        int totalPage = totalCount % pageSize == 0 ? totalCount / pageSize : totalCount / pageSize + 1;
 
        // 设置记录总数和总页数
        resultMap.put("totalCount", totalCount);
        resultMap.put("totalPage", totalPage);
 
        // 按创建时间倒序
        query.with(new Sort(Sort.Direction.DESC, "age"));
        // 查询当前页数据集合
        List<User> records = mongoTemplate.find(query, User.class);
        resultMap.put("data", records);
        return resultMap;
 
    }
 
}

 

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
SQL Java 数据库
【MybatisPlus】MP的分页查询、多条件查询以及查询过程中解决null的空值判定
分页查询、多条件查询以及查询过程中解决null的空值判定
1520 0
【MybatisPlus】MP的分页查询、多条件查询以及查询过程中解决null的空值判定
|
6月前
|
NoSQL MongoDB
使用MongoTemplate 对 mongodb数据进行分组、排序、分页、连表查询
使用MongoTemplate 对 mongodb数据进行分组、排序、分页、连表查询
|
Java
jpa实现增删改查,分页,自定义查询,jpql查询
jpa实现增删改查,分页,自定义查询,jpql查询
88 0
|
6月前
r2dbc分页条件查询
r2dbc分页条件查询
152 0
|
6月前
|
SQL Java Spring
MybatisPlus-条件查询方式及多条件构建查询
MybatisPlus-条件查询方式及多条件构建查询
839 0
|
6月前
|
SQL 算法 关系型数据库
MySQL查询优化之order by 、 group by与分页查询优化
MySQL查询优化之order by 、 group by与分页查询优化
327 0
查询-多条件查询
查询-多条件查询
105 0
查询-多条件查询
|
数据采集 算法 前端开发
查询分页不只有 limit,这四种分页方法值得掌握
查询分页不只有 limit,这四种分页方法值得掌握
264 0
查询分页不只有 limit,这四种分页方法值得掌握