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