自己本科时候一直使用的是Mysql,目前的课题组使用的是MongoDB,因此就花了一部分时间整理了一下,实现springboot与MongoDB的整合,并且实现基本的增删改查操作,从头到尾给出一个完整的案例。

一、环境配置

对于环境配置我是用了一张表来展示,版本之间差异不大,你可以基于其他版本进行测试。




基于spring boot的增删改查 springboot项目增删改查_增删改查


二、代码整合

我们在这里举的例子是对用户类user的增删改查操作。现在我们先看一下现在的项目结构:


基于spring boot的增删改查 springboot项目增删改查_User_02


下面我们就来看一下具体实现步骤。

第一步:在pom中添加依赖


基于spring boot的增删改查 springboot项目增删改查_User_03


第二步:在pom中启动热部署


基于spring boot的增删改查 springboot项目增删改查_User_04


第三步:在application.properties文件中添加全局配置信息


基于spring boot的增删改查 springboot项目增删改查_基于spring boot的增删改查_05


第四步:新建bean包并创建User类


基于spring boot的增删改查 springboot项目增删改查_增删改查功能怎么实现_06


第五步:新建dao包并创建UserRepository接口


基于spring boot的增删改查 springboot项目增删改查_环境配置_07


注意:getByName中的name要和User中的name名字一样,比如这里就不能写成getByUserName,因为匹配的是userName和User中的字段name不同,运行的时候就会出错。

第六步:新建service包并创建UserService接口


基于spring boot的增删改查 springboot项目增删改查_增删改查_08


第七步:在service包创建UserServiceImpl类


基于spring boot的增删改查 springboot项目增删改查_增删改查功能怎么实现_09


在这里你可能有一些疑问,一会使用mongoTemplate,一会又使用userRepository,在每一种情况下到底用哪个,在这里我们就给出一个对比,

(1)使用MongoRepository

使用Repository已经提供了基本的增删改查功能。

对于查询操作:你不用写相关的查询组合语句,它会内部为我们实现这样的一个类。 你只需要按照相关规则就好。

对于增加操作:要有主键才可以,并且不能是date日期类型的。

但是他的缺点是不够灵活,这时候就可以使用MongoTemplate了。

(2)使用MongoTemplate

Spring Data给我们提供了MongoTemplate类,是非常强大的,里面提供了大量的操作数据库的方法,而且是线程安全的。可是它的很多方法都涉及到了Class,和CollectionName。针对不同的实体类,我们需要重复写不同的方法。

第八步:创建controller包并创建Usercontroller类


基于spring boot的增删改查 springboot项目增删改查_基于spring boot的增删改查_10


基于spring boot的增删改查 springboot项目增删改查_增删改查_11


到目前为止我们代码就实现完了。

最后一步,那就是测试:


基于spring boot的增删改查 springboot项目增删改查_增删改查功能怎么实现_12


我们可以在浏览器输入不同的路径测试。当然roto3T也有我们的插入的结果,其他的自己测试一下就好:


基于spring boot的增删改查 springboot项目增删改查_环境配置_13


OK,这就是整合的整个过程,在这里其实也只是给出一个基础案例,希望对你有帮助。