SpringBoot集成MongDB(详细)

本文介绍了如何在SpringBoot应用中集成MongoDB,包括MongoDB的安装、基本操作如创建数据库、集合、插入和更新文档。通过示例详细展示了数据库和集合的管理以及数据的增删改操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、mongDB安装

#拉取镜像

docker pull mongo:latest

#创建和启动容器

docker run -d --restart=always -p 27017:27017 --name mymongo -v /data/db:/data/db -d mongo

#进入容器

docker exec -it mymongo/bin/bash

#使用MongoDB客户端进行操作

mongo

> show dbs #查询所有的数据库

admin 0.000GB

config 0.000GB

local 0.000GB

2、mongDB基本操作命令

2.1、创建数据库(切换/创建数据库)

如果数据库不存在,则创建数据库,否则切换到指定数据库

use huangsiqing

查看show dbs,会发现没有我们创建的数据库,因为操作mongDB需要添加数据

db.hsq.insert({“name”:“菜鸟”})

这时候查看,会发现创建的hsq就算我们的表,而name就是我们的数据
在这里插入图片描述

2.2、创建集合(表),删除集合(表)

MongoDB 中使用 createCollection() 方法来创建集合。

方式一:

db.createCollection(name, options)

例如:db.createCollection(“runoob”)

  • name: 要创建的集合名称
  • options: 可选参数, 指定有关内存大小及索引的选项【可选】

方式二:在 MongoDB 中,你不需要创建集合。当你插入一些文档时,MongoDB 会自动创建集合。

db.mycol2.insert({“name” : “菜鸟”})

MongoDB 中使用 drop() 方法来删除集合。

db.collection.drop()

2.3、插入文档(数据)

方法:

db.COLLECTION_NAME.insert(document)
或
db.COLLECTION_NAME.save(document)
  • save():如果 _id 主键存在则更新数据,如果不存在就插入数据。该方法新版本中已废弃,可以使用 db.collection.insertOne()db.collection.replaceOne() 来代替。
  • insert(): 若插入的数据主键已经存在,则会抛 org.springframework.dao.DuplicateKeyException 异常,提示主键重复,不保存当前数据。

实例1:插入数据

db.col.insert({title: 'MongoDB 教程', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: '菜鸟教程',
    url: 'http://www.runoob.com',
    tags: ['mongodb', 'database', 'NoSQL'],
    likes: 100
})

参数说明:

  • col:是集合(表)
  • 它可以向任何集合中插入

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cHUvNlEQ-1650533206667)(尚医通/image-20220401191946607.png)]

查看已插入的数据:

db.col.find()

实例2:插入数据

 document=({title: 'MongoDB 教程', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: '菜鸟教程',
    url: 'http://www.runoob.com',
    tags: ['mongodb', 'database', 'NoSQL'],
    likes: 100
});

再执行插入命令

db.col.insert(document)

2.4、更新文档(数据)

方式一:update() 方法

update() 方法来更新标题(title):

db.hsq.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}})

在这里插入图片描述

发现值更新了一条。如果你要修改多条相同的文档,则需要设置 multi 参数为 true。

db.hsq.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})

在这里插入图片描述

SpringBoot集成MongDB

### Spring Boot 整合 MongoDB 示例教程 #### 配置依赖 为了使Spring Boot项目能够与MongoDB交互,在`pom.xml`文件中需引入必要的依赖。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> ``` 此操作确保了应用程序具备访问MongoDB所需的功能[^1]。 #### 设置连接信息 在`application.properties`或`application.yml`内指定MongoDB的相关参数。对于单个数据库实例而言,如下所示: 若是采用`.properties`格式,则设置方式为: ``` spring.data.mongodb.uri=mongodb://username:password@localhost:27017/databaseName ``` 而如果是利用`.yml`形式的话,相应的配置应写作: ```yaml spring: data: mongodb: uri: mongodb://username:password@localhost:27017/databaseName ``` 上述命令定义了目标数据库的位置以及认证详情,从而允许程序立有效的链接。 #### 定义实体类 创Java类映射至MongoDB中的文档结构。例如,假设有一个名为`User`的数据模型: ```java import org.springframework.data.annotation.Id; import org.springframework.data.mongodb.core.mapping.Document; @Document(collection = "users") public class User { @Id private String id; private String name; private int age; // Getters and Setters... } ``` 这段代码片段展示了怎样通过注解声明持久化对象及其字段属性。 #### 编写仓库接口 接着要设计用于执行CRUD(增删改查)动作的存储库层。通常继承自`MongoRepository<T, ID>`即可获得基本的操作支持: ```java import org.springframework.data.mongodb.repository.MongoRepository; public interface UserRepository extends MongoRepository<User, String> { } ``` 这一步骤简化了针对特定集合/实施数据检索的过程。 #### 测试功能实现 最后编写单元测试验证整个流程是否正常运作。下面给出了一种可能的方式来进行简单的查询检验: ```java @SpringBootTest class DemoApplicationTests { @Autowired private UserRepository userRepository; @Test void contextLoads() { Iterable<User> users = userRepository.findAll(); for (User user : users) { System.out.println(user.getName()); } } } ``` 以上就是关于如何在一个基于Spring Boot框架构的应用里加入对NoSQL型数据库——MongoDB的支持的一个简单介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值