SpringBoot整合MongoDB超详细
一、介绍
在前面的文章中,我们详细的介绍了 MongoDB 的配置和使用,如果你对 MongoDB 还不是很了解,也没关系,在 MongoDB 中有三个比较重要的名词: 数据库、集合、文档 ! 数据库(Database) :和关系型数据库一样,每个数据库中有自己的用户权限,不同的项目组可以使用不同的数据库集合(Collection) :集合指的是文档组(类似于 Mysql 中的表的概念),里面可以存储许多文档文档(Document) :文档是 MongoDB 中最基本的数据单元,由键值对组成,类似于 JSON 格式,可以存储不同字段,字段的值可以包括其他文档、数组和文档数组
搞懂这三个名词,基本就可以上手了,今天我们以 Java 语言为例,详细的介绍 Java 客户端改如何操作 MongoDB !
话不多说,直接开撸! 二、Java 客户端2.1、MongoDB 连接
Java 连接 MongoDB 服务器,与我们常用的连接关系型数据库方式类似!
标准 URI 连接语法: mongodb://username:password@host1:port1,host2:port2,...,hostN:portN/database?options
参数说明: mongodb:// :这是固定的格式,必须要指定username:password@ :可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登录这个数据库host1:port1 :主机IP和端口号,必须指定至少一个host。如果要连接复制集,请指定多个主机地址/database :如果指定了username:password@ ,连接时会验证并登录指定数据库。若不指定,默认打开 test 数据库?options :连接可选项,例如connectTimeoutMS=5000ms ,表示连接等待时间最长 5 秒
例如,无密码连接 MongoDB mongodb://127.0.0.1:27017
使用用户名 test ,密码test 登录 MongoDB 的test_db 数据库mongodb://test:test@127.0.0.1:27017/test_db
无密码连接指定三台服务器 (端口 27017, 27018, 和27019) mongodb://127.0.0.1:27017,127.0.0.1:27018,127.0.0.1:27019 2.2、添加依赖包
和关系型数据库操作一样,在 Java 程序中如果要使用 MongoDB,先要添加对应的 MongoDB JDBC 驱动器,然后才能继续操作!
在选择的版本号的时候,注意需要和服务器中的安装版本匹配,具体的版本号选择可以从如下地址中获取到最新的版本:mongo-java-driver org.mongodb mongo-java-driver 3.12.7 2.3、连接数据库
连接数据库的 Java 代码如下: private static MongoClient mongoClient; static { try { //连接到MongoDB服务 如果是远程连接可以替换"localhost"为服务器所在IP地址 mongoClient = MongoClients.create("mongodb://test:test@127.0.0.1:27017/test_db"); System.out.println("Connect to database successfully"); } catch (Exception e) { System.err.println( e.getClass().getName() + ": " + e.getMessage() ); } }
上文中采用的是用户名和密码方式登录数据库,因为数据库已经开启了权限验证,因此需要通过用户名和密码才能登录。 2.4、创建集合
com.mongodb.client 包里面都帮我们集成好了大部分常用的 api,我们可以通过MongoDatabase 类中的createCollection() 方法来创建集合。
创建一个 tb_role 集合,代码片段如下:/** * 创建集合 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); mongoDatabase.createCollection("tb_role"); System.out.println("集合创建成功"); }
如果想删除集合,操作也很简单! /** * 删除集合 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); mongoDatabase.getCollection("tb_role").drop(); System.out.println("集合 tb_role 删除成功"); } 2.5、创建文档
我们可以通过 MongoCollection 类中的insertMany() 方法来插入一个文档。
向 tb_role 集合中插入文档,代码片段如下:/** * 插入文档 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); //获取集合 MongoCollection collection = mongoDatabase.getCollection("tb_role"); //向集合中插入文档 Document document = new Document("name", "管理员"). append("code", "manager"). append("sort", 100); List documents = new ArrayList<>(); documents.add(document); collection.insertMany(documents); System.out.println("文档插入成功"); } 2.6、更新文档
我们可以通过 MongoCollection 类中的updateMany() 方法来更新集合中的文档。
更新 tb_role 集合中的指定文档信息,代码片段如下:/** * 更新文档 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); //获取集合 MongoCollection collection = mongoDatabase.getCollection("tb_role"); //更新文档 collection.updateMany(Filters.eq("code", "manager"), new Document("$set",new Document("name","经理"))); //遍历所有文档 FindIterable findIterable = collection.find(); MongoCursor mongoCursor = findIterable.iterator(); while(mongoCursor.hasNext()){ System.out.println(mongoCursor.next()); } }
上文操作类似于 SQL语句中的 update tb_role set name = "经理" where code = "manager" !2.7、删除文档
我们可以通过 MongoCollection 类中的deleteOne() 或者deleteMany 方法来删除集合中的文档。
删除 tb_role 集合中的指定文档信息,代码片段如下:/** * 删除文档 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); //获取集合 MongoCollection collection = mongoDatabase.getCollection("tb_role"); //删除符合条件的第一个文档 collection.deleteOne(Filters.eq("code", "manager")); //删除所有符合条件的文档 collection.deleteMany (Filters.eq("code", "manager")); //遍历所有文档 FindIterable findIterable = collection.find(); MongoCursor mongoCursor = findIterable.iterator(); while(mongoCursor.hasNext()){ System.out.println(mongoCursor.next()); } }
在这里需要注意一下,在删除的时候,官方推荐尽可能先查询一下这个数据是否存在,如果存在,然后在执行删除操作,可以调用 findOneAndDelete() 方法进行删除!2.8、查询文档
MongoCollection 类中提供了非常丰富的检索文档的方法,例如,我们可以通过find() 方法来获取集合中的所有文档。
检索 tb_role 集合中的文档信息,代码片段如下:/** * 查询文档 * @param args */ public static void main(String[] args) { // 连接到数据库 MongoDatabase mongoDatabase = mongoClient.getDatabase("test_db"); System.out.println("Connect to database successfully"); //获取集合 MongoCollection collection = mongoDatabase.getCollection("tb_role"); //遍历所有文档 FindIterable findIterable = collection.find(); MongoCursor mongoCursor = findIterable.iterator(); while(mongoCursor.hasNext()){ System.out.println(mongoCursor.next()); } //查询当前集合所有文档数量 long count = collection.countDocuments(); System.out.println("当前文档数量:" + count); //带条件遍历文档 FindIterable documentFindIterable = collection.find(Filters.eq("code", "manager")); MongoCursor documentMongoCursor = documentFindIterable.iterator(); while(documentMongoCursor.hasNext()){ System.out.println(documentMongoCursor.next()); } } 三、SpringBoot 整合 MongoDB
采用 SpringBoot 来对接 MongoDB,可以说极其简单,下面就以常用的几个操作为例来介绍,过程如下! 3.1、创建 SpringBoot 工程,添加 MongoDB 依赖包 org.springframework.boot spring-boot-starter-parent 2.1.0.RELEASE org.springframework.boot spring-boot-starter-data-mongodb 3.2、添加配置文件
在 application.properties 文件中添加mongodb 配置#配置数据库连接地址 spring.data.mongodb.uri=mongodb://test123:test123@127.0.0.1:27017/test_db 3.3、创建实体类
创建用于示例中测试的实体类 Person 。
其中注解 @Document(collection="persons") 用于指定当前文档属于集合persons 。
注解 @Id 表示当前id 字段属于主键类型。/** * 使用@Document注解指定集合名称 */ @Document(collection="persons") public class Person implements Serializable { private static final long serialVersionUID = -3258839839160856613L; /** * 使用@Id注解指定MongoDB中的 _id 主键 */ @Id private Long id; private String userName; private String passWord; private Integer age; private Date createTime; //...get/set @Override public String toString() { return "Person{" + "id=" + id + ", userName="" + userName + """ + ", passWord="" + passWord + """ + ", age=" + age + ", createTime=" + createTime + "}"; } } 3.4、操作 MongoDB
Springboot 操作 MongoDB 有两种方式。 第一种方式是采用 Springboot 官方推荐的 JPA 方式,这种操作方式,使用简单但是灵活性比较差。 第二种方式是采用 Spring Data MongoDB 封装的 MongoDB 官方 Java 驱动 MongoTemplate 对 MongoDB 进行操作,这种方式非常灵活,能满足绝大部分需求。
本文将采用第二种方式进行介绍! 3.5、插入文档
MongoTemplate 提供了insert() 方法,用于插入文档,示例代码如下:用于插入文档
没指定集合名称时,会取 @Document 注解中的集合名称@RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 插入文档 * @throws Exception */ @Test public void insert() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); mongoTemplate.insert(person); } } 自定义集合名称,插入文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 自定义集合,插入文档 * @throws Exception */ @Test public void insertCustomCollection() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); mongoTemplate.insert(person, "custom_person"); } } 自定义集合,批量插入文档
如果采用批量插入文档,必须指定集合名称 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 自定义集合,批量插入文档 * @throws Exception */ @Test public void insertBatch() throws Exception { List personList = new ArrayList<>(); Person person1 =new Person(); person1.setId(10l); person1.setUserName("张三"); person1.setPassWord("123456"); person1.setCreateTime(new Date()); personList.add(person1); Person person2 =new Person(); person2.setId(11l); person2.setUserName("李四"); person2.setPassWord("123456"); person2.setCreateTime(new Date()); personList.add(person2); mongoTemplate.insert(personList, "custom_person"); } } 3.6、存储文档
MongoTemplate 提供了save() 方法,用于存储文档。
在存储文档的时候会通过主键ID进行判断,如果存在就更新,否则就插入,示例代码如下: 存储文档,如果没有插入,否则通过 主键ID 更新@RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 存储文档,如果没有插入,否则更新 * @throws Exception */ @Test public void save() throws Exception { Person person =new Person(); person.setId(13l); person.setUserName("八八"); person.setPassWord("123456"); person.setAge(40); person.setCreateTime(new Date()); mongoTemplate.save(person); } } 自定义集合,存储文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 自定义集合,存储文档 * @throws Exception */ @Test public void saveCustomCollection() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); mongoTemplate.save(person, "custom_person"); } } 3.7、更新文档
MongoTemplate 提供了updateFirst() 和updateMulti() 方法,用于更新文档,示例代码如下:更新文档,匹配查询到的文档数据中的第一条数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 更新文档,匹配查询到的文档数据中的第一条数据 * @throws Exception */ @Test public void updateFirst() throws Exception { //更新对象 Person person =new Person(); person.setId(1l); person.setUserName("张三123"); person.setPassWord("123456"); person.setCreateTime(new Date()); //更新条件 Query query= new Query(Criteria.where("id").is(person.getId())); //更新值 Update update= new Update().set("userName", person.getUserName()).set("passWord", person.getPassWord()); //更新查询满足条件的文档数据(第一条) UpdateResult result =mongoTemplate.updateFirst(query,update, Person.class); if(result!=null){ System.out.println("更新条数:" + result.getMatchedCount()); } } } 更新文档,匹配查询到的文档数据中的所有数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 更新文档,匹配查询到的文档数据中的所有数据 * @throws Exception */ @Test public void updateMany() throws Exception { //更新对象 Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); //更新条件 Query query= new Query(Criteria.where("id").is(person.getId())); //更新值 Update update= new Update().set("userName", person.getUserName()).set("passWord", person.getPassWord()); //更新查询满足条件的文档数据(全部) UpdateResult result = mongoTemplate.updateMulti(query, update, Person.class); if(result!=null){ System.out.println("更新条数:" + result.getMatchedCount()); } } } 3.8、删除文档
MongoTemplate 提供了remove() 、findAndRemove() 和findAllAndRemove() 方法,用于删除文档,示例代码如下:删除符合条件的所有文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 删除符合条件的所有文档 * @throws Exception */ @Test public void remove() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); Query query = new Query(Criteria.where("userName").is(person.getUserName())); DeleteResult result = mongoTemplate.remove(query, Person.class); System.out.println("删除条数:" + result.getDeletedCount()); } } 删除符合条件的单个文档,并返回删除的文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 删除符合条件的单个文档,并返回删除的文档 * @throws Exception */ @Test public void findAndRemove() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); Query query = new Query(Criteria.where("id").is(person.getId())); Person result = mongoTemplate.findAndRemove(query, Person.class); System.out.println("删除的文档数据:" + result.toString()); } } 删除符合条件的所有文档,并返回删除的文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 删除符合条件的所有文档,并返回删除的文档 * @throws Exception */ @Test public void findAllAndRemove() throws Exception { Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); Query query = new Query(Criteria.where("id").is(person.getId())); List result = mongoTemplate.findAllAndRemove(query, Person.class); System.out.println("删除的文档数据:" + result.toString()); } } 3.9、查询文档
MongoTemplate 提供了非常多的文档查询方法,日常开发中用的最多的就是find() 方法,示例代码如下:查询集合中的全部文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 查询集合中的全部文档数据 * @throws Exception */ @Test public void findAll() throws Exception { List result = mongoTemplate.findAll(Person.class); System.out.println("查询结果:" + result.toString()); } } 查询集合中指定的ID文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 查询集合中指定的ID文档数据 * @throws Exception */ @Test public void findById() { long id = 1l; Person result = mongoTemplate.findById(id, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据条件查询集合中符合条件的文档,返回第一条数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据条件查询集合中符合条件的文档,返回第一条数据 */ @Test public void findOne() { String userName = "张三"; Query query = new Query(Criteria.where("userName").is(userName)); Person result = mongoTemplate.findOne(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据条件查询集合中符合条件的文档 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据条件查询集合中符合条件的文档 */ @Test public void findByCondition() { String userName = "张三"; Query query = new Query(Criteria.where("userName").is(userName)); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据【AND】关联多个查询条件,查询集合中的文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据【AND】关联多个查询条件,查询集合中的文档数据 */ @Test public void findByAndCondition() { // 创建条件 Criteria criteriaUserName = Criteria.where("userName").is("张三"); Criteria criteriaPassWord = Criteria.where("passWord").is("123456"); // 创建条件对象,将上面条件进行 AND 关联 Criteria criteria = new Criteria().andOperator(criteriaUserName, criteriaPassWord); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据【OR】关联多个查询条件,查询集合中的文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据【OR】关联多个查询条件,查询集合中的文档数据 */ @Test public void findByOrCondition() { // 创建条件 Criteria criteriaUserName = Criteria.where("userName").is("张三"); Criteria criteriaPassWord = Criteria.where("passWord").is("123456"); // 创建条件对象,将上面条件进行 OR 关联 Criteria criteria = new Criteria().orOperator(criteriaUserName, criteriaPassWord); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据【IN】关联多个查询条件,查询集合中的文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据【IN】关联多个查询条件,查询集合中的文档数据 */ @Test public void findByInCondition() { // 设置查询条件参数 List ids = Arrays.asList(1l, 10l, 11l); // 创建条件 Criteria criteria = Criteria.where("id").in(ids); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据【逻辑运算符】查询集合中的文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据【逻辑运算符】查询集合中的文档数据 */ @Test public void findByOperator() { // 设置查询条件参数 int min = 20; int max = 35; Criteria criteria = Criteria.where("age").gt(min).lte(max); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据【正则表达式】查询集合中的文档数据 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据【正则表达式】查询集合中的文档数据 */ @Test public void findByRegex() { // 设置查询条件参数 String regex = "^张*"; Criteria criteria = Criteria.where("userName").regex(regex); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据条件查询集合中符合条件的文档,获取其文档列表并排序 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据条件查询集合中符合条件的文档,获取其文档列表并排序 */ @Test public void findByConditionAndSort() { String userName = "张三"; Query query = new Query(Criteria.where("userName").is(userName)).with(Sort.by("age")); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 根据单个条件查询集合中的文档数据,并按指定字段进行排序与限制指定数目 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据单个条件查询集合中的文档数据,并按指定字段进行排序与限制指定数目 */ @Test public void findByConditionAndSortLimit() { String userName = "张三"; //从第一行开始,查询2条数据返回 Query query = new Query(Criteria.where("userName").is(userName)).with(Sort.by("createTime")).limit(2).skip(1); List result = mongoTemplate.find(query, Person.class); System.out.println("查询结果:" + result.toString()); } } 统计集合中符合【查询条件】的文档【数量】 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 统计集合中符合【查询条件】的文档【数量】 */ @Test public void countNumber() { // 设置查询条件参数 String regex = "^张*"; Criteria criteria = Criteria.where("userName").regex(regex); // 创建查询对象,然后将条件对象添加到其中 Query query = new Query(criteria); long count = mongoTemplate.count(query, Person.class); System.out.println("统计结果:" + count); } } 4.0、创建索引
索引在所有的数据库中,暂居的位置非常重要,例如当你检索一张上百万的数据表的时候,如果没走索引,查询效率会极其缓慢,对于 MongoDB 来说,同样如此。
示例如下: 创建升序索引 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 创建升序索引 */ @Test public void createAscendingIndex() { // 设置字段名称 String field = "userName"; // 创建索引 mongoTemplate.getCollection("persons").createIndex(Indexes.ascending(field)); } } 移除索引 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 根据索引名称移除索引 */ @Test public void removeIndex() { // 设置字段名称 String field = "userName"; // 删除索引 mongoTemplate.getCollection("persons").dropIndex(field); } } 查询集合中所有的索引 @RunWith(SpringRunner.class) @SpringBootTest public class PersonServiceTest { @Autowired private MongoTemplate mongoTemplate; /** * 查询集合中所有的索引 */ @Test public void getIndexAll() { // 获取集合中所有列表 ListIndexesIterable indexList = mongoTemplate.getCollection("persons").listIndexes(); // 获取集合中全部索引信息 for (Document document : indexList) { System.out.println("索引列表:" + document); } } } 我们还可以通过在实体类上加注解方式来创建索引 /** * 使用@Document注解指定集合名称 */ @Document(collection="persons") public class Person implements Serializable { private static final long serialVersionUID = -3258839839160856613L; /** * 使用@Id注解指定MongoDB中的 _id 主键 */ @Id private Long id; private String userName; private String passWord; private Integer age; /** * 创建一个5秒之后文档自动删除的索引 */ @Indexed(expireAfterSeconds=5) private Date createTime; //...get/set @Override public String toString() { return "Person{" + "id=" + id + ", userName="" + userName + """ + ", passWord="" + passWord + """ + ", age=" + age + ", createTime=" + createTime + "}"; } } 4.1、引入 MongoDB 中的事务
单节点 mongodb 不支持事务,需要搭建 MongoDB 复制集。 /** * 配置事务管理器 * */ @Configuration public class TransactionConfig { @Bean MongoTransactionManager transactionManager(MongoDatabaseFactory dbFactory) { return new MongoTransactionManager(dbFactory); } }
事务服务测试! @Service public class TransactionExample { @Autowired private MongoTemplate mongoTemplate; @Transactional(rollbackFor = Exception.class) public Object transactionTest(){ Person person =new Person(); person.setId(1l); person.setUserName("张三"); person.setPassWord("123456"); person.setCreateTime(new Date()); Person newPerson = mongoTemplate.insert(person); // 抛出异常,观察数据是否进行回滚 if(1 == 1){ throw new RuntimeException("异常"); } return newPerson; } } 四、小结
本文主要围绕 MongoDB 的 Java 客户端使用进行基本的增删改查操作介绍,在实际的业务场景中,可能还需要用到聚合函数等高级查询,大家如果有这种需求,可以访问如下地址获取更加详细的 api 文档介绍:MongoDB 文档查询 api 介绍
demo获取地址:https://github.com/justdojava/springboot-example-mongodb 五、参考
1、菜鸟教程 - mongodb
2、超级小豆丁 - MongoDB 介绍
字节教育研发自主学习系统开创智能学习新赛道字节教育大力智能学习灯除了拥有有助近视防控的护眼黑科技之外,字节教育的这款台灯还研发了KidsInside自主学习系统,培养孩子自主学习的好习惯,同时减少家长不必要的辅导负担。字节
区块链,开启智慧养老新时代来源人民网近年来,随着5G云计算物联网人工智能大数据等新一代信息技术的蓬勃发展,数字化网络化智能化的设施和解决方案与城市全面数字化转型加快结合,智慧养老已经来到我们身边。区块链在养
世界智能制造大会举办来源人民网人民日报2021世界智能制造大会于12月8日10日在南京举办。大会由江苏省人民政府工业和信息化部中国工程院中国科学技术协会共同主办,以数字化转型智能化引领为主题,采取线上
商汤科技隐私保护遭提问CEO徐立一直在探讨人工智能治理边界主持人谢谢管理层的介绍,我们现在进入问答的环节,请大家在提问栏输入您的问题,中英文频道的媒体朋友都可以您的语言输入问题,我们将会读出您的问题让管理层现场回答。问答环节将以普通话进行
1000多元的手机都是垃圾吗?感谢您的阅读!1000多元的手机都是垃圾吗?1000多块钱的手机真的是垃圾手机吗?现在的很多手机厂商都推出了千元手机,而千元手机并不像大家想象的是垃圾手机。其实,我们可以看到,特别
人工智能时代,神经网络的原理及使用方法微课堂人工智能时代已经悄然来临,在计算机技术高速发展的未来,机器是否能代替人脑?也许有些读者会说,永远不可能,因为人脑的思考包含感性逻辑。事实上,神经网络算法正是在模仿人脑的思考方式。想
Python机器学习(十)经典算法大全1。KNN分类算法由于knn算法涉及到距离的概念,KNN算法需要先进行归一化处理1。1归一化处理scalerfromsklearn。preprocessingimportStand
老司机归纳经典SQL语句(二)三技巧111,12的使用,在SQL语句组合时用的较多where11是表示选择全部where12全部不选,如ifstrWhere!beginsetstrSQLselectcount(
MetaWorld经济体全球首创多维元宇宙2021年,后疫情时代全世界加速深度数字化的天时,人工智能区块链等在5G的加持下渐趋成熟的地利,人们逐渐习惯于虚拟化数字社交的人和,共同引爆了元宇宙这一新兴赛道。在区块链领域深耕多
log4j2的修复方案建议修复方案推荐选这种1log4j2。x相关jar包统一升级到2。10。02。14。1内任意版本,并配置JVM启动参数Dlog4j2。formatMsgNoLookupstrue2
SQL不难的嘛如果真的要说程序员普遍常用的语言,那应该就是SQL了。作为一门和数据库打交道的语言,无论是前端后端,还是运维web开发,多少都需要写一些SQL,尤其是随着互联网业务数据量的暴增,现
视频分析技术的三大新兴趋势人工智能跟踪人脸微表情在最近的一篇博客中,我们看到了视频分析如何成为提供更好城市监控的有用解决方案。在这里,我们将更详细地阐述视频分析的技术能力。市场规模预计将从2016年的16。9亿美元增长到2021
2022年5个值得关注的AI趋势,一分钟看明白根据2020年麦肯锡全球人工智能(AI)调查,2020年,超过50的公司已经在至少一个业务部门或职能部门采用了人工智能,因此我们见证了新的人工智能趋势的出现。科技公司将至少20的利
三星QDOLED电视来了2022年CES发布QLED显示技术虽然在高端市场拥有不错的市场占有率,但从技术原理来看,现阶段依旧是光质发光(需要背光源),而OLED天然就是自发光,画质和形态上的潜力巨大。此前,三星官方已确认将于
蓝色巨人IBM大象转身业务自我分拆的断舍离2020年的10月8日,蓝色巨人IBM宣布将在2021年底之前,剥离全球科技服务业务中的基础设施服务托管部门,并组建一家新公司NewCo。NewCo将专注于企业基础设施管理和现代化
炒股巨亏后又见资本运作!云南白药要约收购万隆控股财联社(上海,编辑周新旸)讯,在三季度爆出因炒股而蒙受15。6亿元浮亏后,云南白药近期已遭到投资者颇多批评。但该公司周四稍晚又对外公布一项收购计划,拟对一家港股公司发起要约收购。1
从阿亚冲突的无人机打坦克,看未来战争格局国庆假期国外最大的新闻,一个是川普得了新冠,博了全球媒体的眼球,其实更让人深思的是亚美尼亚和阿斯拜疆的领土争端引起的战争,从阿斯拜疆公布的视频中,可以看到,亚美尼亚的坦克和炮兵在被
对标大疆索尼首款无人机问世还记得去年11月索尼公司启动的Airpeak人工智能无人机项目吗?今天它来了。今日,索尼在CES2021展会上,推出其首款无人机航拍设备Airpeak,借此索尼正式进军无人机领域。
帝王品质给交易者们带来了什么指引?今天,我们来看看马可奥勒留罗马的最后一位好皇帝的生活心态,以及交易是如何为我们实现他的斯多葛主义提供了巨大的机会。这篇文章是斯多葛交易者系列文章的第二部分。在上一篇文章中,我们学习
是雪中送炭还是锦上添花,聊聊智能家居那些事现在是智能时代,家居也不能免俗。好比如今的家电产品,不给自己贴上智能这两个字,都不好意思说自己是一台摆在卖场里的电器。当智能二字被如此广泛地滥用之际,我来聊一聊智能家居的那些事。在
AI安防智能化发展至今还存在哪些问题?安防行业是AI人工智能落地比较成熟的应用领域,其先进性和未来的可发展性是毋庸置疑的。在人工智能技术落地安防领域之后,的确为安防行业带来了翻天覆地的变化,智能化数据化和便捷化的优势赋
人工智能专业术语物体识别卷积神经网络YOLO分别都是什么?初学者区分不同的相关计算机视觉任务可能具有挑战性。例如,图像分类比较易于理解,但目标定位和目标检测之间的差异可能会令人困惑,尤其是当所有三个任务都可以等同地称为目标识别时。图像分类