Spring Boot系列(八) Spring Boot中使用MongoDB資料庫

來源:互聯網
上載者:User
            Spring Boot系列(八) Spring Boot中使用MongoDB資料庫

這一篇介紹Spring Boot中使用MongoDB資料庫,需要springboot實戰完整視頻教程的,點擊這裡。


MongoDB是一個開源的NoSQL文檔資料庫,它使用一個JSON格式的模式(schema)替換了傳統的基於表的關係資料。Spring Boot為使用MongoDB提供了很多便利,包括spring-boot-starter-data-mongodb 'Starter POM'。


引入spring-boot-starter-data-mongodb包,在pom.xml設定檔中增加如下內容(基於之前章節“Spring Boot 構建架構”中的pom.xml檔案):


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


注入一個自動設定的org.springframework.data.mongodb.MongoDbFactory來訪問Mongo資料庫。預設情況下,該執行個體將嘗試使用URL: mongodb://localhost/test串連一個MongoDB伺服器。


import org.springframework.data.mongodb.MongoDbFactory;
import com.mongodb.DB;
@Component
public class MyBean {
   private final MongoDbFactory mongo;
   
   @Autowired
   public MyBean(MongoDbFactory mongo) {
       this.mongo = mongo;
   }
   
   // ...
   public void example() {
   DB db = mongo.getDb();
       // ...
   }
}


可以通過設定spring.data.mongodb.uri來改變該url,或指定一個host/port。在application.properties中設定如下的屬性:


spring.data.mongodb.host=mongoserver
spring.data.mongodb.port=27017


注意:如果沒有指定spring.data.mongodb.port,那將使用預設的連接埠27017。可以簡單的從上面的樣本中刪除這一行。如果不使用Spring Data Mongo,可以注入com.mongodb.Mongo beans而不是使用MongoDbFactory。如果想全面控制MongoDB串連的建立,也可以聲明自己的MongoDbFactory或Mongo,@Beans。


MongoDBTemplate

Spring Data Mongo提供了一個MongoTemplate類,它的設計和Spring的JdbcTemplate很相似。正如JdbcTemplate一樣,Spring Boot會自動設定一個bean,你只需簡單的注入它即可:


import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.stereotype.Component;
@Component
public class MyBean {
   private final MongoTemplate mongoTemplate;
   
   @Autowired
   public MyBean(MongoTemplate mongoTemplate) {
       this.mongoTemplate = mongoTemplate;
   }
   // ...
}


應用整合MongoDB案例

在application.properties設定檔中新增內容如下:


spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test


多個IP叢集採用以下配置:


spring.data.mongodb.uri=mongodb://user:pass@ip1:port1,ip2:port2/database


建立資料實體類,具體代碼如下:


public class UserInfo implements Serializable {
   private Long id;
   private String userName;
   private String passWord;
   //getter、setter省略
}


建立實體類對應dao層,實現增刪改查操作,具體代碼如下:


@Component
public class UserInfoDaoImpl implements UserInfoDao {// UserInfoDao 自訂介面
   @Autowired
   private MongoTemplate mongoTemplate;
   /**
    * 建立對象
    * @param user
    */
   @Override
   public void saveUser(UserInfo user) {
       mongoTemplate.save(user);
   }
   /**
    * 根據使用者名稱查詢對象
    * @param userName
    * @return
    */
   @Override
   public UserInfo findUserByUserName(String userName) {
       Query query=new Query(Criteria.where("userName").is(userName));
       UserInfo user =  mongoTemplate.findOne(query , UserInfo.class);
       return user;
   }
   /**
    * 更新對象
    * @param user
    */
   @Override
   public void updateUser(UserInfo user) {
       Query query=new Query(Criteria.where("id").is(user.getId()));
       Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord());
       //更新查詢返回結果集的第一條
       mongoTemplate.updateFirst(query,update,UserInfo.class);
       //更新查詢返回結果集的所有
       // mongoTemplate.updateMulti(query,update,UserInfo.class);
   }
   /**
    * 刪除對象
    * @param id
    */
   @Override
   public void deleteUserById(Long id) {
       Query query=new Query(Criteria.where("id").is(id));
       mongoTemplate.remove(query,UserInfo.class);
   }
}


簡單測試方法,具體代碼如下:


@RunWith(SpringRunner.class)
@SpringBootTest
public class UserDaoTest {
   @Autowired
   private UserDao userDao;
   @Test
   public void testSaveUser() throws Exception {
       UserInfo user=new UserInfo();
       user.setId(2);
       user.setUserName("路人甲");
       user.setPassWord("123456");
       userDao.saveUser(user);
   }
   @Test
   public void findUserByUserName(){
      UserInfo user= userDao.findUserByUserName("路人甲");
      System.out.println("user is "+user);
   }
   @Test
   public void updateUser(){
       UserInfo user=new UserInfo();
       user.setId(3
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.