MongoDB是一个跨平台的,面向文档的数据库,是当前NoSQL数据库产品中最热门的一种。它介于关系数据库和非关系数据库之间,是非关系数据库当中功能最丰富,最像关系数据库的产品。它支持的数据结构非常松散,是类似 JSON的BSON 格式,因此可以存储比较复杂的数据类型。
1、MongoDB适合的应用场景
数据量大、写入操作频繁和数据价值较低,比如社区的评论功能。
2、Docker环境下安装MongoDB
docker run -di --name=onelun_mongo -p 27017:27017 mongo
3、常用命令
user <数据库名称> # 选择和创建数据库
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。
# 这时会发现数据只剩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() # 统计记录数
db.spit.count({userid:"1"}) # 统计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引入依赖
org.springframework.boot
spring‐boot‐starter‐data‐mongodb
创建application.yml
spring:
data:
mongodb:
host: 192.168.3.186
database: spitdb
创建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 .....
}
创建数据访问接口
public interface SpitDao extends MongoRepository{
/**
*根据上级ID查询吐槽列表(分页)
*/
public Page findByParentid(String parentid,Pageable pageable);
}
业务逻辑SpitService类和控制层SpitController类
public Page 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 pageList = spitService.findByParentid(parentId,page, size);
return new Result(true,StatusCode.OK,"查询成功",new PageResult(pageList.getTotalElements(), pageList.getContent()));
}