对于mongodb,使用了不存在的对象,就等于在创建这个对象
一, 创建数据库
注意:操作数据库的方式:db.表名(Collections).操作(参数)
二,增
插入数据(insert insertOne insertMany)
insert:插入一条或者多条数据,需要带有允许插入多条的参数,这个方法目前官方已经不推荐
使用insertOne插入一条数据:
db.user.insertOne({id: 4, name: "qqq", age: 20}) # 插入一条数据
db.user.insertMany([{id: 7, name: "www", age: 20}, {id: 8},{id:9}]) # 插入多条数据
三,删
db.user.remove({}) # 官方不推荐使用了
db.user.deleteOne({id:7}) # 删除一条id=7的数据
db.user.deleteMany({name:"ttt"}) # 删除所有name=“ttt"的数据
db.user.deleteMany({}) # 清空数据库
db.user.drop() # 清空数据库
三, 改
db.user.updateOne({id:1},{$set:{name:"花大炮"}}) # 修改id为1的数据的 name为花大炮
db.user.updateMany({age:20},{$set:{name:"jjj"}}) # 修改age=20的所有数据的 name为"jjj"
db.user.updateMany({age:20},{$set:{hobby: ["ooo", "xxx"]}}) # 可以直接修改为一个数组
针对Field的$修改器
$set 修改器之一 设定 将某Key设定为某值:
db.user.updateMany({age:20},{$set:{name:"jjj"}})
$unset:删除当前的Fields
db.user.updateOne({id:7}, {$unset: {hobby: "" }}) # 把id为7的数据,删除hobby这个字段
db.user.updateOne({id:4}, {$unset: {hobby: 0 }}) # 把id为4的数据,删除hobby这个字段
$inc 在原有值基础上增加 (int类型,就是增加或减少之(负数),string类型,就是字符串拼接)
db.user.updateOne({name:"mmm"},{$inc: {age:5}}) # 给name="mmm"的数据,的age在原来的基础上加上5
针对Arrays的$修改器
$push 在Arrays中添加一个元素
db.user.updateOne({name: "mmm"},{$push:{hobby:"哈哈"}}) # 给name="mmm"的数据中的hobby对于的值(列表),中添加一个值为"哈哈”
db.user.updateOne({name: "jjj"},{$push: {hobby: "dfd"}}) # 该条数据没有字段hobby,则创建一个hobby,把数据放进
db.user.updateOne({name:"mmm"},{$push:{hobby: ["ccc","vvv", "bbb"]}}) 只添加第一个进去
db.user.updateOne({name:"mmm"},{$pushAll:{hobby: ["ccc","vvv", "bbb"]}}) 把列表整体添加进去
$pull 在Arrays中删除一个元素
db.user.updateOne({name:"mmm"},{$pull: {hobby:"ccc"}}) # 在name=mmm这条数据的hobby对应的列表中删掉ccc
$pop 在Arrays中删除最后一个元素或第一个元素
db.user.updateOne({name:"mmm"}, {$pop: {hobby:-1}}) 删除第一个
db.user.updateOne({name: "mmm"},{$pop:{hobby: 1}}) 删除最后一个
$ : 存储 满足前置条件列表元素的下标索引
db.user.updateOne({name: "mmm", hobby: "哈哈"},{$set:{"hobby.$": "大西瓜"}}) # 将name="mmm"这条数据中的hobby对应的列表中的 “哈哈”,改成“大西瓜”
上面的$就是记录前面的"哈哈"在hobby中的索引,所以也可以直接这么写:
db.user.updateOne({name: "mmm"},{$set:{"hobby.0": "绿苹果"}}) # 修改name="mmm"的数据中的hobby索引为0的值为"绿苹果"
db.user.updateOne({name: "mmm"},{$set:{"hobby.1": "大西瓜"}})
混合用法
db.user.updateOne({name:"hhh"},{$set:{course:[
{course_name: "python", score:100},
{course_name: "vue", score:101},
{course_name: "mysql", score:99}
]}}) # 插入数据
db.user.updateOne({name: "hhh", "course.course_name":"python"},{$inc:{"course.$.score": 10}}) # $获取了前面数据的索引
db.user.updateOne({name: "hhh"},{$inc:{"course.0.score": 20}})
四,查
db.user.find({}) # 查询所有数据
db.user.findOne({name:"lll"}) # 查询name=“lll"的数据
$lt 小于 $gt 大于 $lte 小于等于 $gte 大于等于 $eq : 等于
db.user.find({age:{$lte:19}}) # 查询age小于等于19的数据
db.user.find({age:{$gt:19}}) # 查询age大于19的数据
查询$关键字:
{
"_id" : ObjectId("5bc6eac2613e5c72d4c888b0"),
"id" : 10,
"name" : "mmm",
"age" : 30,
"hobby" : [
"绿苹果",
"大西瓜",
"小红枣",
"ccc",
"vvv"
]
}
对于上述数据:
$all 满足所有元素的数据
db.user.find({hobby: {$all: ["大西瓜"]}}) # 可以找到
db.user.find({hobby: {$all: ["大西瓜", "ccc"]}}) # 可以找到
# 主要元素在数据中,就可以找到,可以和原始数据不一样!
$in 满足其中一个元素的数据
db.user.find({hobby: {$in: ["ccc", "vvv"]}}) # 数据在要查询数据的hobby中就可以查到
$or 满足其中一个字段的数据
db.user.find({$or: [{name:"lll"}, {id:1}]}) # 查询 name=”lll“ 或者 id=1的数据
db.user.deleteMany({$or:[{id:8},{id:9}]}) # 删除id=8 或者 id=9的数据
limit(x):
只查询前x条数据
skip(x):
跳过前x条数据
sort({ id:-1 }):
根据id字段进行倒序排列:-1 正序排列:1
分页使用
db.user.find({}).sort({id:1}).skip(0).limit(3) # 第一页
db.user.find({}).sort({id:1}).skip(3).limit(3) # 第二页
db.user.find({}).sort({id:1}).skip(6).limit(3) # 第三页
db.user.find({}).sort({id:1}).skip(9).limit(3) # 第四页
db.user.find({}).sort({id:1}).skip(12).limit(3) # 第五页
学无止境!