自己本科时候一直使用的是Mysql,目前的课题组使用的是MongoDB,因此就花了一部分时间整理了一下,实现springboot与MongoDB的整合,并且实现基本的增删改查操作,从头到尾给出一个完整的案例。
一、环境配置
对于环境配置我是用了一张表来展示,版本之间差异不大,你可以基于其他版本进行测试。
二、代码整合
我们在这里举的例子是对用户类user的增删改查操作。现在我们先看一下现在的项目结构:
下面我们就来看一下具体实现步骤。
第一步:在pom中添加依赖
第二步:在pom中启动热部署
第三步:在application.properties文件中添加全局配置信息
第四步:新建bean包并创建User类
第五步:新建dao包并创建UserRepository接口
注意:getByName中的name要和User中的name名字一样,比如这里就不能写成getByUserName,因为匹配的是userName和User中的字段name不同,运行的时候就会出错。
第六步:新建service包并创建UserService接口
第七步:在service包创建UserServiceImpl类
在这里你可能有一些疑问,一会使用mongoTemplate,一会又使用userRepository,在每一种情况下到底用哪个,在这里我们就给出一个对比,
(1)使用MongoRepository
使用Repository已经提供了基本的增删改查功能。
对于查询操作:你不用写相关的查询组合语句,它会内部为我们实现这样的一个类。你只需要按照相关规则就好。
对于增加操作:要有主键才可以,并且不能是date日期类型的。
但是他的缺点是不够灵活,这时候就可以使用MongoTemplate了。
(2)使用MongoTemplate
SpringData给我们提供了MongoTemplate类,是非常强大的,里面提供了大量的操作数据库的方法,而且是线程安全的。可是它的很多方法都涉及到了Class,和CollectionName。针对不同的实体类,我们需要重复写不同的方法。
第八步:创建controller包并创建Usercontroller类
到目前为止我们代码就实现完了。
最后一步,那就是测试:
我们可以在浏览器输入不同的路径测试。当然roto3T也有我们的插入的结果,其他的自己测试一下就好:
OK,这就是整合的整个过程,在这里其实也只是给出一个基础案例,希望对你有帮助。