资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

MongoDB数据库如何在springboot项目中使用

MongoDB数据库如何在spring boot项目中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

公司主营业务:成都做网站、网站设计、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出麻山免费做网站回馈大家。

依赖


 org.springframework.boot
 spring-boot-starter-data-mongodb


//还有一个依赖,官方demo里加的有,这个应该是启动的时候帮你下载mongodb数据库的,反正我是没有成功下载下来过,一直timeout,如果系统上装的有mongodb了,就不用要这个依赖了

 de.flapdoodle.embed
 de.flapdoodle.embed.mongo

配置

实体类只用加一个@Id就可以了

import org.springframework.data.annotation.Id;

public class User {

 @Id
 private String id;
 private String username;

 // getter, setter
}

数据库配置

spring:
 freemarker:
 template-loader-path:
 - file:./templates
 data:
 mongodb:
  database: dbname #一般只用配置这一个就可以了,如果数据库有密码,还要配置下面几个配置
  host: 
  password:
  uri:

Repository要继承的是MongoRepository,跟踪代码可以发现MongoRepository继承的就是PagingAndSortingRepository,所以分页之类的一些简单的方法也是可以直接拿来用的,非常方便

public interface UserRepository extends MongoRepository {
 User findByUsername(String username);
}

spring-data怎么用,这里就怎么用

关联

MongoDB在spring-boot里没法做关联,所以用MySQL做关联的 @ManyToOne 这些注解也就不能用了

经我测试,如果在Blog实体类里引入User对象,在保存Blog的时候,User对象也会保存在Blog里,如下所示

{ 
 "_id" : ObjectId("59cb127b23d8213c8dfdcad9"), 
 "_class" : "com.example.module.blog.model.Blog", 
 "title" : "hello world", 
 "content" : "hello world", 
 "inTime" : ISODate("2017-09-27T02:52:43.713+0000"), 
 "user" : {
 "_id" : ObjectId("59cb0fec23d8213930c6795a"), 
 "username" : "tomoya", 
 "inTime" : ISODate("2017-09-27T02:41:48.402+0000")
 }
}

如果修改User的username,只会修改user表里的username,blog表里的user对象里的username是不会变的,所以这里建议关联只给一个id,在查询的时候用id去查user,再封装到一块比较好

关于MongoDB数据库如何在spring boot项目中使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


当前标题:MongoDB数据库如何在springboot项目中使用
当前路径:http://cdkjz.cn/article/pdphhs.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220