MongoDB作為一種NoSQL數據庫產品,其實已經非常著名了。去年,由于MongoDB安全認證的薄弱,上萬家公司中招。雖然是一則負面新聞,但是也從側面說明了MongoDB的流行程度。
下圖是DB-Engines統計的2017年5月全球數據庫引擎使用排名。從圖中可以看出,mongoDB位列總榜第五,非關系數據庫第一,非??壳暗呐琶?。

我個人對mongoDB并不是非常熟悉,但是經過一段時間的了解,對mongoDB的特性還是有了一些簡單的理解,這里記錄一二。
話說了這么多,還是要回到實際使用上。這里我將使用Spring Boot來操作mongoDB,Spring Boot由于有Spring Data的支持,使用mongoDB還是比較輕松方便的。
方法如下:
首先是添加Spring Data mongo的配置依賴,如下所示:
compile("org.springframework.boot:spring-boot-starter-data-mongodb")
其次是在application.properties中配置mongoDB的連接參數,如下所示:
spring.data.mongodb.uri=mongodb://localhost:27017/dbname
Spring Boot配置就是這樣簡單,然后就是具體的代碼編寫了。首先,需要定義一個實體類,這里用一個User的簡單實體類來說明:
@Document(collection = "users")
public class User {
@Id
private String id;
private String username;
private Integer age;
}
這段代碼里面省略了getter和setter,所以看起來非常簡單。值得注意的一點是@Document注解,它是mongoDB專用的。了解mongoDB的話,都知道collection之于mongoDB,就像關系數據庫的table一樣。通過指定collection,可以實現實體類到mongoDB集合的映射關系。如果不顯式指定collection,Spring會根據實體類的名字去推測集合的名字。
配置完畢,實體類也實現完畢,我們需要的就是實現mongoDB的各種操作,從而把數據庫和應用程序連接起來。按照Spring data的現狀,實現數據庫操作大概有兩種方式——MongoRepository、mongoTemplate。MongoRepository是一種相對簡單的方式,它可以幫我們輕松的實現簡答的CRUD操作。
下面就是它的使用方式:
public interface UserRepository extends MongoRepository<User, Long>{
User findByUsername(String username);
}
然后在使用數據庫的地方直接依賴注入UserRepository即可。的確非常簡單,這是因為Spring幫我們做了兩件事,首先Spring會為Repository生成bean,一般來說Spring內置的Repository及其子類都使用了@NoRepositoryBean注解,所以只有用戶定義的沒有該注解的interface才會被實例化一個bean。其次Spring會根據interface中的方法名,去自動生成CRUD操作的函數,因此我們連實現代碼都不用寫了。
使用MongoTemplate會稍微麻煩一點,但同時它能夠完成的工作也更多一些。下面是使用mongoTemplate的方式,為了展示其強大的能力,我們使用一個稍微復雜點例子。
代碼如下:
@Component
public class ArticleRepositoryImpl {
MongoTemplate mongoTemplate;
@Autowired
public ArticleRepositoryImpl(MongoTemplate mongoTemplate) {
this.mongoTemplate = mongoTemplate;
}
public List<Article> find(Query query) {
return mongoTemplate.find(query, Article.class);
}
public Article findOne(Query query) {
return mongoTemplate.findOne(query, Article.class);
}
public void update(Query query, Update update) {
mongoTemplate.findAndModify(query, update, Article.class);
}
public Article save(Article article) {
mongoTemplate.insert(article);
return article;
}
public Article findById(String id) {
return mongoTemplate.findById(id, Article.class);
}
public Page<Article> findPage(Page<Article> page, Query query) {
long count = count(query);
int pageNumber = page.getPageNumber();
int pageSize = page.getPageSize();
query.skip((pageNumber - 1) * pageSize).limit(pageSize);
List<Article> rows = find(query);
page.setContent(rows);
return page;
}
public long count(Query query) {
return mongoTemplate.count(query, Article.class);
}
}
對于Article這個實體類,我們其實不需要太關心它的細節。為了實現分頁查詢的功能(主要在findPage中實現),代碼使用了略微復雜的查詢操作,這里就體現到了mongoTemplate的更為強大的定制化操作能力。而這里的component注解也只是一種聲明bean的方式。除了它之外,還有很多配置的方式,但功能都是一樣的,這里也就不深究了。
把數據庫的結果通過一個RESTful的接口返回去,就可以看到數據庫的查詢結果,代碼如下所示:
@RestController
public class SimpleRestController {
private UserRepository userRepository;
@Autowired
public SimpleRestController(UserRepository userRepository) {
this.userRepository = userRepository;
}
@RequestMapping(value="/users", method = RequestMethod.GET)
public List<User> greeting(@RequestParam(value = "name", defaultValue = "World") String name) {
return userRepository.findAll();
}
}
通過瀏覽器的訪問結果如下所示:

總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。