Mongodb操作与Java(四)MongoTemplate的利用

打印 上一主题 下一主题

主题 541|帖子 541|积分 1623

目次
mongoClient和MongoTemplate二者区别
代码实践
配置
SpringBoot 工程依靠和配置
准备代码
创建实体类
新增 
插入文档
存储文档
更新
删除文档
查询
变乱

媒介-与正文无关
​    生活远不止眼前的苦劳与奔忙,它还充满了无数值得我们去体验和珍惜的美功德物。在这个快节奏的天下中,我们往往容易陷入工作的漩涡,忘记了停下脚步,感受周围的天下。让我们一起提醒本身,要适时放慢脚步,欣赏生活中的每一道风景,享受与家人朋侪的温馨韶光,发现那些平凡日子里隐蔽的幸福时刻。由于,这些点点滴滴汇聚起来的,才是构成我们丰富多彩生活的本质。渴望每个人都能在繁忙的生活中找到本身的快乐之源,不仅仅为了生存而工作,更为了更好的生活而生活.
​       送你张美图!渴望你开心!



mongoClient和MongoTemplate二者区别

Springboot 操作 MongoDB 有两种方式。
第一种方式是采用 Springboot 官方保举的 JPA 方式,这种操作方式,利用简朴但是机动性比较差。也就是MongoClient
第二种方式是采用 Spring Data MongoDB 基于 MongoDB 官方 Java API 封装的 MongoTemplate 操作类对 MongoDB 进行操作,这种方式非常机动,能满意绝大部分需求。也就是MongoTemplate
本文将采用第二种方式进行先容!
MongoClient
MongoClient 是 MongoDB 官方 Java 驱动库提供的类。可以明确为是mysql的Jdbc框架,它直接与 MongoDB 服务器进行通讯,负责建立毗连、发送查询和命令以及接收响应。利用 MongoClient 通常涉及到编写比较底层的代码。你需要本身管理毗连、编写查询语句、处置惩罚效果集等。它提供了与 MongoDB 交互的最大机动性,允许你实行几乎所有类型的数据库操作,包括那些 Spring Data MongoDB 大概尚未提供支持的操作。

MongoTemplate
界说MongoTemplate 是 Spring Data MongoDB 提供的一个高级抽象,它封装了 MongoClient,提供了一个更高层次的模板方法 API 来简化 MongoDB 的操作。可以明确为是mysql的Mybatis框架。MongoTemplate 提供了相对简朴的方法来实行查询、更新、删除等操作,同时集成了 Spring 的转换和异常处置惩罚机制。利用 MongoTemplate,你不需要关心低层次的数据库毗连和错误处置惩罚。

代码实践

配置

SpringBoot 工程依靠和配置

  1. <!-- 引入springboot -->
  2. <parent>
  3.     <groupId>org.springframework.boot</groupId>
  4.     <artifactId>spring-boot-starter-parent</artifactId>
  5.     <version>2.1.0.RELEASE</version>
  6. </parent>
  7. <dependency>
  8.     <groupId>org.springframework.boot</groupId>
  9.     <artifactId>spring-boot-starter-data-mongodb</artifactId>
  10. </dependency>
复制代码
添加配置文件
在application.properties文件中添加mongodb相干配置!
   #配置数据库毗连地址
spring.data.mongodb.uri=mongodb://userName:password@127.0.0.1:27017/dbName
  

  • userName:体现用户名,根据实际情况填写即可
  

  • password:体现用户暗码,根据实际情况填写即可
  

  • dbName:体现数据库,可以自界说,初始化数据的时候,会主动创建
  准备代码

创建实体类

创建一个实体类Person,此中注解@Document(collection="persons")体现当前实体类对应的集合名称是persons,类似于关系型数据库中的表名称。
注解@Id体现当前字段,在集合布局中属于主键类型。
  1. /**
  2. * 使用@Document注解指定集合名称
  3. */
  4. @Document(collection="persons")
  5. public class Person implements Serializable {
  6.     private static final long serialVersionUID = -3258839839160856613L;
  7.     /**
  8.      * 使用@Id注解指定MongoDB中的 _id 主键
  9.      */
  10.     @Id
  11.     private Long id;
  12.     private String userName;
  13.     private String passWord;
  14.     private Integer age;
  15.     private Date createTime;
  16.     //...get/set
  17.     @Override
  18.     public String toString() {
  19.         return "Person{" +
  20.                 "id=" + id +
  21.                 ", userName='" + userName + '\'' +
  22.                 ", passWord='" + passWord + '\'' +
  23.                 ", age=" + age +
  24.                 ", createTime=" + createTime +
  25.                 '}';
  26.     }
  27. }
复制代码
新增 

插入文档

MongoTemplate提供了insert()方法,用于插入文档,示例代码如下:


  • 用于插入文档
   没指定集合名称时,会取 @Document注解中的集合名称  
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 插入文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void insert() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(1l);
  14.         person.setUserName("张三");
  15.         person.setPassWord("123456");
  16.         person.setCreateTime(new Date());
  17.         mongoTemplate.insert(person);
  18.     }
  19. }
复制代码


  • 自界说集合名称,插入文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 自定义集合,插入文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void insertCustomCollection() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(1l);
  14.         person.setUserName("张三");
  15.         person.setPassWord("123456");
  16.         person.setCreateTime(new Date());
  17.         mongoTemplate.insert(person, "custom_person");
  18.     }
  19. }
复制代码


  • 自界说集合,批量插入文档
   假如采用批量插入文档,必须指定集合名称
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 自定义集合,批量插入文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void insertBatch() throws Exception {
  12.         List<Person> personList = new ArrayList<>();
  13.         Person person1 =new Person();
  14.         person1.setId(10l);
  15.         person1.setUserName("张三");
  16.         person1.setPassWord("123456");
  17.         person1.setCreateTime(new Date());
  18.         personList.add(person1);
  19.         Person person2 =new Person();
  20.         person2.setId(11l);
  21.         person2.setUserName("李四");
  22.         person2.setPassWord("123456");
  23.         person2.setCreateTime(new Date());
  24.         personList.add(person2);
  25.         mongoTemplate.insert(personList, "custom_person");
  26.     }
  27. }
复制代码
存储文档

MongoTemplate提供了save()方法,用于存储文档。
在存储文档的时候会通过主键 ID 进行判断,假如存在就更新,否则就插入,示例代码如下:


  • 存储文档,假如没有插入,否则通过主键ID更新
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 存储文档,如果没有插入,否则更新
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void save() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(13l);
  14.         person.setUserName("八八");
  15.         person.setPassWord("123456");
  16.         person.setAge(40);
  17.         person.setCreateTime(new Date());
  18.         mongoTemplate.save(person);
  19.     }
  20. }
复制代码


  • 自界说集合,存储文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 自定义集合,存储文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void saveCustomCollection() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(1l);
  14.         person.setUserName("张三");
  15.         person.setPassWord("123456");
  16.         person.setCreateTime(new Date());
  17.         mongoTemplate.save(person, "custom_person");
  18.     }
  19. }
复制代码
更新

MongoTemplate提供了updateFirst()和updateMulti()方法,用于更新文档,示例代码如下:


  • 更新文档,匹配查询到的文档数据中的第一条数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 更新文档,匹配查询到的文档数据中的第一条数据
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void updateFirst() throws Exception {
  12.         //更新对象
  13.         Person person =new Person();
  14.         person.setId(1l);
  15.         person.setUserName("张三123");
  16.         person.setPassWord("123456");
  17.         person.setCreateTime(new Date());
  18.         //更新条件
  19.         Query query= new Query(Criteria.where("id").is(person.getId()));
  20.         //更新值
  21.         Update update= new Update().set("userName", person.getUserName()).set("passWord", person.getPassWord());
  22.         //更新查询满足条件的文档数据(第一条)
  23.         UpdateResult result =mongoTemplate.updateFirst(query,update, Person.class);
  24.         if(result!=null){
  25.             System.out.println("更新条数:" + result.getMatchedCount());
  26.         }
  27.     }
  28. }
复制代码


  • 更新文档,匹配查询到的文档数据中的所有数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 更新文档,匹配查询到的文档数据中的所有数据
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void updateMany() throws Exception {
  12.         //更新对象
  13.         Person person =new Person();
  14.         person.setId(1l);
  15.         person.setUserName("张三");
  16.         person.setPassWord("123456");
  17.         person.setCreateTime(new Date());
  18.         //更新条件
  19.         Query query= new Query(Criteria.where("id").is(person.getId()));
  20.         //更新值
  21.         Update update= new Update().set("userName", person.getUserName()).set("passWord", person.getPassWord());
  22.         //更新查询满足条件的文档数据(全部)
  23.         UpdateResult result = mongoTemplate.updateMulti(query, update, Person.class);
  24.         if(result!=null){
  25.             System.out.println("更新条数:" + result.getMatchedCount());
  26.         }
  27.     }
  28. }
复制代码

删除文档

MongoTemplate提供了remove()、findAndRemove()和findAllAndRemove()方法,用于删除文档,示例代码如下:


  • 删除符合条件的所有文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 更新文档,匹配查询到的文档数据中的所有数据
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void updateMany() throws Exception {
  12.         //更新对象
  13.         Person person =new Person();
  14.         person.setId(1l);
  15.         person.setUserName("张三");
  16.         person.setPassWord("123456");
  17.         person.setCreateTime(new Date());
  18.         //更新条件
  19.         Query query= new Query(Criteria.where("id").is(person.getId()));
  20.         //更新值
  21.         Update update= new Update().set("userName", person.getUserName()).set("passWord", person.getPassWord());
  22.         //更新查询满足条件的文档数据(全部)
  23.         UpdateResult result = mongoTemplate.updateMulti(query, update, Person.class);
  24.         if(result!=null){
  25.             System.out.println("更新条数:" + result.getMatchedCount());
  26.         }
  27.     }
  28. }
复制代码


  • 删除符合条件的单个文档,并返回删除的文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 删除符合条件的单个文档,并返回删除的文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void findAndRemove() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(1l);
  14.         person.setUserName("张三");
  15.         person.setPassWord("123456");
  16.         person.setCreateTime(new Date());
  17.         Query query = new Query(Criteria.where("id").is(person.getId()));
  18.         Person result = mongoTemplate.findAndRemove(query, Person.class);
  19.         System.out.println("删除的文档数据:" + result.toString());
  20.     }
  21. }
复制代码


  • 删除符合条件的所有文档,并返回删除的文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 删除符合条件的所有文档,并返回删除的文档
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void findAllAndRemove() throws Exception {
  12.         Person person =new Person();
  13.         person.setId(1l);
  14.         person.setUserName("张三");
  15.         person.setPassWord("123456");
  16.         person.setCreateTime(new Date());
  17.         Query query = new Query(Criteria.where("id").is(person.getId()));
  18.         List<Person> result = mongoTemplate.findAllAndRemove(query, Person.class);
  19.         System.out.println("删除的文档数据:" + result.toString());
  20.     }
  21. }
复制代码
查询


MongoTemplate提供了非常多的文档查询方法,日常开辟中用的最多的就是find()方法,示例代码如下:


  • 查询集合中的全部文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 查询集合中的全部文档数据
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void findAll() throws Exception {
  12.         List<Person> result = mongoTemplate.findAll(Person.class);
  13.         System.out.println("查询结果:" + result.toString());
  14.     }
  15. }
复制代码


  • 查询集合中指定的ID文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 查询集合中指定的ID文档数据
  8.      * @throws Exception
  9.      */
  10.     @Test
  11.     public void findById() {
  12.         long id = 1l;
  13.         Person result = mongoTemplate.findById(id, Person.class);
  14.         System.out.println("查询结果:" + result.toString());
  15.     }
  16. }
复制代码


  • 根据条件查询集合中符合条件的文档,返回第一条数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据条件查询集合中符合条件的文档,返回第一条数据
  8.      */
  9.     @Test
  10.     public void findOne() {
  11.         String userName = "张三";
  12.         Query query = new Query(Criteria.where("userName").is(userName));
  13.         Person result = mongoTemplate.findOne(query, Person.class);
  14.         System.out.println("查询结果:" + result.toString());
  15.     }
  16. }
复制代码



  • 根据条件查询集合中符合条件的文档
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据条件查询集合中符合条件的文档
  8.      */
  9.     @Test
  10.     public void findByCondition() {
  11.         String userName = "张三";
  12.         Query query = new Query(Criteria.where("userName").is(userName));
  13.         List<Person> result = mongoTemplate.find(query, Person.class);
  14.         System.out.println("查询结果:" + result.toString());
  15.     }
  16. }
复制代码



  • 根据【AND】关联多个查询条件,查询集合中的文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据【AND】关联多个查询条件,查询集合中的文档数据
  8.      */
  9.     @Test
  10.     public void findByAndCondition() {
  11.         // 创建条件
  12.         Criteria criteriaUserName = Criteria.where("userName").is("张三");
  13.         Criteria criteriaPassWord = Criteria.where("passWord").is("123456");
  14.         // 创建条件对象,将上面条件进行 AND 关联
  15.         Criteria criteria = new Criteria().andOperator(criteriaUserName, criteriaPassWord);
  16.         // 创建查询对象,然后将条件对象添加到其中
  17.         Query query = new Query(criteria);
  18.         List<Person> result = mongoTemplate.find(query, Person.class);
  19.         System.out.println("查询结果:" + result.toString());
  20.     }
  21. }
复制代码


  • 根据【OR】关联多个查询条件,查询集合中的文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据【OR】关联多个查询条件,查询集合中的文档数据
  8.      */
  9.     @Test
  10.     public void findByOrCondition() {
  11.         // 创建条件
  12.         Criteria criteriaUserName = Criteria.where("userName").is("张三");
  13.         Criteria criteriaPassWord = Criteria.where("passWord").is("123456");
  14.         // 创建条件对象,将上面条件进行 OR 关联
  15.         Criteria criteria = new Criteria().orOperator(criteriaUserName, criteriaPassWord);
  16.         // 创建查询对象,然后将条件对象添加到其中
  17.         Query query = new Query(criteria);
  18.         List<Person> result = mongoTemplate.find(query, Person.class);
  19.         System.out.println("查询结果:" + result.toString());
  20.     }
  21. }
复制代码



  • 根据【IN】关联多个查询条件,查询集合中的文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据【IN】关联多个查询条件,查询集合中的文档数据
  8.      */
  9.     @Test
  10.     public void findByInCondition() {
  11.         // 设置查询条件参数
  12.         List<Long> ids = Arrays.asList(1l, 10l, 11l);
  13.         // 创建条件
  14.         Criteria criteria = Criteria.where("id").in(ids);
  15.         // 创建查询对象,然后将条件对象添加到其中
  16.         Query query = new Query(criteria);
  17.         List<Person> result = mongoTemplate.find(query, Person.class);
  18.         System.out.println("查询结果:" + result.toString());
  19.     }
  20. }
复制代码



  • 根据【逻辑运算符】查询集合中的文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据【逻辑运算符】查询集合中的文档数据
  8.      */
  9.     @Test
  10.     public void findByOperator() {
  11.         // 设置查询条件参数
  12.         int min = 20;
  13.         int max = 35;
  14.         Criteria criteria = Criteria.where("age").gt(min).lte(max);
  15.         // 创建查询对象,然后将条件对象添加到其中
  16.         Query query = new Query(criteria);
  17.         List<Person> result = mongoTemplate.find(query, Person.class);
  18.         System.out.println("查询结果:" + result.toString());
  19.     }
  20. }
复制代码



  • 根据【正则表达式】查询集合中的文档数据
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.     /**
  7.      * 根据【正则表达式】查询集合中的文档数据
  8.      */
  9.     @Test
  10.     public void findByRegex() {
  11.         // 设置查询条件参数
  12.         String regex = "^张*";
  13.         Criteria criteria = Criteria.where("userName").regex(regex);
  14.         // 创建查询对象,然后将条件对象添加到其中
  15.         Query query = new Query(criteria);
  16.         List<Person> result = mongoTemplate.find(query, Person.class);
  17.         System.out.println("查询结果:" + result.toString());
  18.     }
  19. }
复制代码


  • 根据单个条件查询集合中的文档数据,并按指定字段进行排序与限制指定命目
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.    /**
  7.      * 根据单个条件查询集合中的文档数据,并按指定字段进行排序与限制指定数目
  8.      */
  9.     @Test
  10.     public void findByConditionAndSortLimit() {
  11.         String userName = "张三";
  12.         //从第一行开始,查询2条数据返回
  13.         Query query = new Query(Criteria.where("userName").is(userName)).with(Sort.by("createTime")).limit(2).skip(1);
  14.         List<Person> result = mongoTemplate.find(query, Person.class);
  15.         System.out.println("查询结果:" + result.toString());
  16.     }
  17. }
复制代码



  • 统计集合中符合【查询条件】的文档【数目】
  1. @RunWith(SpringRunner.class)
  2. @SpringBootTest
  3. public class PersonServiceTest {
  4.     @Autowired
  5.     private MongoTemplate mongoTemplate;
  6.    /**
  7.      * 统计集合中符合【查询条件】的文档【数量】
  8.      */
  9.     @Test
  10.     public void countNumber() {
  11.         // 设置查询条件参数
  12.         String regex = "^张*";
  13.         Criteria criteria = Criteria.where("userName").regex(regex);
  14.         // 创建查询对象,然后将条件对象添加到其中
  15.         Query query = new Query(criteria);
  16.         long count = mongoTemplate.count(query, Person.class);
  17.         System.out.println("统计结果:" + count);
  18.     }
  19. }
复制代码
变乱

单节点 mongodb 不支持变乱,需要搭建 MongoDB 复制集才有变乱,利用方式和mysql一样在springboot中。


------------------------------------------与正文内容无关------------------------------------ 假如觉的文章写对各位读者老爷们有资助的话,麻烦点赞加关注呗!作者在这拜谢了!
混口饭吃了!假如你需要Java 、Python毕设、商务合作、技术交换、就业引导、技术支持度过试用期。请在关注私信我,本人看到肯定马上回复!
这是我全部文章所在目次,看看是否有你需要的,假如遇到以为不对地方请留言,看到后我会查阅进行改正。
A乐神-CSDN博客
关注在文章左上角,作者信息处。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

小秦哥

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表