2的10次方学习总结-MongoDB
常见的异常
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QE7uVJqk-1672814483856)(null)]
第二天 MongoDB
docker安装mongodb快速使用 :http://t.zoukankan.com/banbosuiyue-p-13094105.html
MongoDB是一个开源、高性能、无模式的文档型数据库。它可以解决需要存储数据量大、高并发读写、高可用的现实问题,适用于社交朋友圈、游戏积分、物流轨迹、商品评论等业务。架构成本较低,各方面却很优秀。
它的特点是高性能、易部署、易使用,存储数据非常方便。
- MongoDB 的文档(document),相当于关系数据库中的一行记录。
- 多个文档组成一个集合(collection),相当于关系数据库的表。
- 多个集合(collection),逻辑上组织在一起,就是数据库(database)。
- 一个 MongoDB 实例支持多个数据库(database)。
数据库(databases) 数据库(databases)
集合(collections) 表(table)
文档(document) 行(row)
选择和创建数据库的语法格式:use commentdb
查看数据库: show dbs
查看集合,需要先选择数据库之后,才能查看该数据库的集合:show collections
选择数据库后,使用集合来对文档进行操作,插入文档语法格式:
db.集合名称.insert(数据);
插入以下测试数据:
db.comment.insert({content:“十次方课程”,userid:“1011”})
查询集合的语法格式:db.集合名称.find()
按一定条件来查询,比如查询userid为1013的记录,只要在find()中添加参数即可,
参数也是json格式,如下:
db.comment.find({userid:‘1013’})
只需要返回符合条件的第一条数据,我们可以使用 findOne命令来实现:
db.comment.findOne({userid:‘1013’})
返回指定条数的记录,可以在 find方法后调用limit来返回结果,例如:
db.comment.find().limit(2)
修改文档的语法结构:
db.集合名称.update(条件,修改后的数据)**
db.comment.update({_id:“2”},{$set:{thumbup:2000}})
删除文档的语法结构:
db.集合名称.remove(条件)
以下语句可以将数据全部删除,慎用 ~
db.comment.remove({})
删除条件可以放到大括号中,例如删除 thumbup为1000的数据,输入以下语句:
db.comment.remove({thumbup:1000})
统计条数
统计记录条件使用count()方法。以下语句统计spit集合的记录数:
db.comment.count()
按条件统计 ,例如统计userid为1013的记录条数:
db.comment.count({userid:“1013”})
模糊查询
MongoDB的模糊查询是通过正则表达式的方式实现的。格式为:
/模糊查询字符串/
查询评论内容包含 “流量”的所有文档,代码如下:
db.comment.find({content:/流量/})
查询评论内容中以“加班”开头的,
db.comment.find({content:/^加班/})
查询评论内容中以“加班”结尾的,
db.comment.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” : { KaTeX parse error: Expected 'EOF', got '}' at position 11: ne: value }̲}) // 不等 于: fie…gt:1000}})
包含与不包含
包含使用KaTeX parse error: Expected '}', got 'EOF' at end of input: ….find({userid:{in:[“1013”,“1014”]}})**
不包含使用KaTeX parse error: Expected '}', got 'EOF' at end of input: ….find({userid:{nin:[“1013”,“1014”]}})**
条件连接
1、使用$and操作符将条件进行关联(相当于SQL的and)
查询评论集合中 thumbup大于等于1000 并且小于2000的文档:
db.comment.find({KaTeX parse error: Expected '}', got 'EOF' at end of input: …nd:[ {thumbup:{gte:1000}} ,{thumbup:{$lt:2000} }]})
2、如果两个以上条件之间是或者的关系 KaTeX parse error: Expected '}', got 'EOF' at end of input: ….comment.find({or:[ {userid:“1013”} ,{thumbup:{$lt:2000} }]})
2.3.9 列值增长
对某列值在原有值的基础上进行增加或减少,可以使用KaTeX parse error: Expected '}', got 'EOF' at end of input: …ate({_id:"2"},{inc:{thumbup:1}})
//新增
Document document = new Document(map);
comment.insertOne(document);//查询
FindIterable documents =comment.find(new BasicDBObject(“_id”, “1”));//修改的条件
Bson filter = new BasicDBObject(“_id”, “6”);
//修改的数据
Bson update = new BasicDBObject(“$set”, new
Document(“userid”, “8888”));
comment.updateOne(filter, update);//删除的条件
Bson filter = new BasicDBObject(“_id”, “6”);
comment.deleteOne(filter);
添加依赖
org.springframework.boot spring-boot-starter-data-mongodb
配置文件
@Autowired
private MongoTemplate mongoTemplate;