spring-boot項目裏的MongoDB的用法">spring-boot項目裏的MongoDB的用法

分類:IT技術 時間:2017-09-28

前言:mysql數據庫很好用,但數據量到了千萬以上了,想增加字段是非常痛苦的,這個在MongoDB裏就不存在,字段想怎麽加就怎麽加,所以也就有了想在spring-boot裏用MongoDB的想法了,Github上spring-projects裏有關於使用MongoDB的demo,後面會給出鏈接

依賴

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

//還有一個依賴,官方demo裏加的有,這個應該是啟動的時候幫你下載mongodb數據庫的,反正我是沒有成功下載下來過,一直timeout,如果系統上裝的有mongodb了,就不用要這個依賴了
<dependency>
  <groupId>de.flapdoodle.embed</groupId>
  <artifactId>de.flapdoodle.embed.mongo</artifactId>
</dependency>

配置

實體類只用加一個@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, String> {
  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,再封裝到一塊比較好

參考

  • https://github.com/spring-projects/spring-boot/tree/master/spring-boot-samples/spring-boot-sample-data-mongodb

Tags: 配置 MongoDB artifactId dependency gt lt

文章來源:


ads
ads

相關文章
ads

相關文章

ad