MongoDB是一個跨平臺的,面向文檔的數據庫薯蝎,是當前NoSQL數據庫產品中最熱門的一種导而。它介于關系數據庫和非關系數據庫之間,是非關系數據庫當中功能最豐富管挟,最像關系數據庫的產品轿曙。它支持的數據結構非常松散,是類似 JSON的BSON 格式僻孝,因此可以存儲比較復雜的數據類型导帝。
1、MongoDB適合的應用場景
數據量大穿铆、寫入操作頻繁和數據價值較低您单,比如社區(qū)的評論功能。
2荞雏、Docker環(huán)境下安裝MongoDB
docker run -di --name=onelun_mongo -p 27017:27017 mongo
3虐秦、常用命令
user <數據庫名稱> # 選擇和創(chuàng)建數據庫
db.<集合名稱>.insert(數據) # 插入文檔
db.spit.insert({content:"我很帥",userid:"1",visits:NumberInt(902)})
db.<集合名稱>.find() # 查詢集合
db.spit.find() # 查詢全部spit數據
db.spit.find({userid:"1"}) # 查詢userid為1的spit數據
db.spit.findOne({userid:"1"}) # 查詢1條userid為1的spit數據
db.spit.find().limit(3) # 查詢指定條數記錄
db.<集合名稱>.update(條件,修改后的數據) # 修改文檔
db.spit.update({_id:"1"},{visits:NumberInt(1000)}) # 修改_id為1的記錄,瀏覽量為1000凤优。
# 這時會發(fā)現數據只剩visits了悦陋,為了解決這個問題, 我們可以用$set修改器來實現筑辨,命令如下
db.spit.update({_id:"2"},{$set:{visits:NumberInt(2000)}}) #
db.<集合名稱>.remove(條件) # 刪除文檔
db.spit.remove({}) # 刪除全部數據俺驶,慎用
db.spit.remove({visits:1000}) #刪除visits=1000的記錄
db.spit.count() # 統(tǒng)計記錄數
db.spit.count({userid:"1"}) # 統(tǒng)計userid為0的記錄數
db.spit.find({content:/流量/}) # 模糊查詢,正則表達式實現的
db.spit.find({content:/^加班/}) # 以“加班”開頭的內容模糊查詢
db.<集合名稱>.find({"field": {$gt: value}}) # 大于: field > value
db.<集合名稱>.find({"field": {$lt: value}}) # 小于: field < value
db.<集合名稱>.find({"field": {$gte: value}}) # 大于等于: field >= value
db.<集合名稱>.find({"field": {$lte: value}}) # 小于等于: field <= value
db.<集合名稱>.find({"field": {$ne: value}}) # 不等于: field != value
db.spit.find({visits:{$gt:1000}}) # 查詢吐槽瀏覽量大于1000的記錄
db.spit.find({userid:{$in:["1013","1014"]}} # 包含查詢
db.spit.find({userid:{$nin:["1013","1014"]}} # 不包含查詢
$and:[ { },{ },{ } ] # 條件查詢
$or:[ { },{ },{ } ]
db.spit.find({$and:[{visits:{$gte:1000}},{visits:{$lt:2000}}]})
db.spit.find({$or:[{visits:{$gte:1000}},{visits:{$lt:2000}}]})
# 如果我們想實現對某列值在原有值的基礎上進行增加或減少挖垛,可以使用$inc運算符來實現
db.spit.update({_id:"1",{$inc:{visits:NumberInt(1)}}})
4痒钝、實例SpringDataMongoDB
pom.xml引入依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring‐boot‐starter‐data‐mongodb</artifactId>
</dependency>
創(chuàng)建application.yml
spring:
data:
mongodb:
host: 192.168.3.186
database: spitdb
創(chuàng)建spit實體類
/**
* 吐槽
* @author Administrator
*/
public class Spit implements Serializable{
@Id
private String _id;
private String content;
private Date publishtime;
private String userid;
private String nickname;
private Integer visits;
private Integer thumbup;
private Integer share;
private Integer comment;
private String state;
private String parentid;
// getter and setter .....
}
創(chuàng)建數據訪問接口
public interface SpitDao extends MongoRepository<Spit, String>{
/**
*根據上級ID查詢吐槽列表(分頁)
*/
public Page<Spit> findByParentid(String parentid,Pageable pageable);
}
業(yè)務邏輯SpitService類和控制層SpitController類
public Page<Spit> findByParentid(String parentid,int page, int size){
PageRequest pageRequest = PageRequest.of(page‐1, size);
return spitDao.findByParentid(parentid, pageRequest);
}
@RequestMapping(value="/comment/{parentId}/{page}/{size}",method=RequestM ethod.GET)
public Result findByParentid(@PathVariable String parentId, @PathVariable int page,@PathVariable int size){
Page<Spit> pageList = spitService.findByParentid(parentId,page, size);
return new Result(true,StatusCode.OK,"查詢成功",new PageResult<Spit>(pageList.getTotalElements(), pageList.getContent()));
}