您现在的位置是:首页 >技术交流 >系列六、MongoDB文档相关操作网站首页技术交流

系列六、MongoDB文档相关操作

YYAugenstern 2024-08-24 12:01:03
简介系列六、MongoDB文档相关操作

一、插入文档

1.1、单条插入

# 语法
db.集合名称.insert({json数据})

# 案例
db.user.insert({
	"name":"张三",
	"age":23,
	"birthday":"1997-07-07"
})

 1.2、多条插入

# insertMany语法:
db.collection.insertMany(
   [ <document 1> , <document 2>, ... ],
   {
      writeConcern: <document>,
      ordered: <boolean>
   }
)
参数说明:
    document:要写入的文档。
    writeConcern:写入策略,默认为 1,即要求确认写操作,0 是不要求。
    ordered:指定是否按顺序写入,默认 true,按顺序写入。
# 案例:

db.user.insertMany(
	[
		{
			"name":"唐僧",
			"age":123
		},
		{
			"id":1,
			"name":"孙悟空",
			"age":500
		},
	]
)

===============================================
# 使用insert也可以实现多条插入

db.user.insert(
	[
		{
			"name":"抓八戒",
			"age":160
		},
		{
			"id":2,
			"name":"沙悟净",
			"age":250
		},
	]
)

 1.3、脚本方式

# 语法
for (let i = 0; i < num; i++) {
	db.集合名称.insert({"_id":i+10,"name":"李白","age":20+i});
}
# 案例
for (let i = 0; i < 10; i++) {
	db.user.insert({"_id":i+10,"name":"李白","age":20+i});
}

 二、查询

2.1、语法

db.集合名称.find(query, projection)
参数说明:
    query: 可选,使用查询操作符指定查询条件
    projection: 可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)

如果需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:
db.集合名称.find().pretty()

MongoDB vs RDBMS where语句比较

2.2、查询所有

# 语法:
db.集合名称.find()

# 案例:查询user表中所有的记录
db.user.find()
db.user.find().pretty()

 2.3、等值查询

# 等值查询语法
db.集合名称.find({key:value})

# 案例:查询user集合中,年龄为24的所有文档
db.user.find({age:24}).pretty()

2.4、非等值查询

2.4.1、小于查询

# 语法
db.集合名称.find({key:{$lt:value}}).pretty()
# 案例:查询user集合中,年龄小于25岁的所有文档
db.user.find({age:{$lt:25}}).pretty()

2.4.2、小于等于查询

# 小于等于
db.集合名称.find({key:{$lte:value}}).pretty()
# 案例:查询user集合中,年龄小于等于25岁的所有文档
db.user.find({age:{$lte:25}}).pretty()

 

2.4.3、大于查询

# 大于
db.集合名称.find({key:{$gt:value}}).pretty()
# 案例:查询user集合中,年龄大于25岁的所有文档
db.user.find({age:{$gt:25}}).pretty()

2.4.4、大于等于查询

# 大于等于
db.集合名称.find({key:{$gte:value}}).pretty()
# 案例:查询user集合中,年龄大于等于25岁的所有文档
db.user.find({age:{$gte:25}}).pretty()

2.4.5、不等于查询

# 不等于
db.集合名称.find({key:{$ne:value}}).pretty()
# 案例:查询user集合中,年龄不等于25岁的所有文档
db.user.find({age:{$ne:25}}).pretty()

 2.5、and查询

# 语法
db.集合名称.find({key1:value1,key2:value2,...}).pretty()
类似于MySQL中的 where key1 = value1 and key2 = value2
# 案例:查询user集合中id为10,并且姓名为李白的文档
db.user.find({_id:10,name:"李白"}).pretty()

# 案例:查询user集合中name为李白,并且id大于5的所有文档

db.user.find({name:"李白",_id:{$gt:5}}).pretty()

# 案例
查询user集合中name为李白,并且name为李太白的所用文档

db.user.find({name:'李白',name:'李太白'}).pretty()

注意事项:and查询时,同一个字段如果出现了多次,那么后边的将会把前边的条件覆盖掉

 2.6、or查询

# 语法
db.集合名称.find(
   {
      $or: [
         {key1: value1}, {key2:value2}
      ]
   }
).pretty()
# 案例:查询id为1或者name为李太白的所有文档信息
db.user.find({$or:[{_id:1},{name:'李太白'}]}).pretty()

# 案例二:查询user集合中id为1,或者年龄大于24的所有文档集合
db.user.find({$or:[{_id:1},{age:{$gt:24}}]}).pretty()

 2.7、and和or联合查询

# 语法
db.集合名称.find({key1:value1,$or:[{key2:value2},{key3:value3}]}).pretty()

类似于MySQL中的 where age > 50 and (name = '李白' or name = '杜甫')
# 案例:查询user集合中age大于24,并且name为李太白或者name为杜甫的所有文档列表
db.user.find({age:{$gt:24},$or:[{name:'李太白'},{name:'杜甫'}]}).pretty()

 2.8、数组查询

# 语法
db.集合名称.find({数组名:value}).pretty()
# 案例:查询user集合中,兴趣爱好为"读书"的文档记录
db.user.find({likes:'读书'}).pretty()

# 案例:查询user集合中,喜好为6的文档列表
db.user.find({likes:{$size:6}}).pretty()

db.user.find({likes:{$size:2}}).pretty()

 

 2.9、模糊查询

# 语法:
db.集合名称.find({key:/value/}).pretty()

# 注意事项
在MongoDB中使用正则表达式,可以实现近似于模糊查询的功能
# 案例一、查询user集合中name字段中包含 白 的所有文档信息
db.user.find({name:/白/}).pretty()

 2.10、排序查询

# 语法
db.集合名称.find().sort({key1:1,key2:-1,...}).pretty()

说明:
1:升序,类似于MySQL中的asc
-1:降序,类似于MySQL中的desc
# 案例:查询user集合中的所有文档,按照id降序排序
db.user.find().sort({_id:-1}).pretty()

2.11、分页查询

# 语法
db.集合名称.find().skip(跳过的记录数).limit(size)
类似于SQL语句:limit start,rows


# 案例1:查询user集合中的前2条记录
db.user.find().skip(0).limit(2)

# 案例2:查询user集合中的第3、4条记录
db.user.find().skip(2).limit(2)

 2.12、总条数查询

# 语法
db.集合名称.count();
db.集合名称.find({key:value}).count();
类似于SQL语句:select count(id) from ...
# 初始化SQL脚本
for (let i = 1; i <= 100000; i++) {
	db.orders.insert({
		_id: i,
		name: 'order_' + i
	});
}


# 案例一:查询orders集合中共有多少条记录
db.orders.count()

# 案例二:查询orders集合中,name为order_100的文档共有多少个
db.orders.find({name:'order_100'}).count()

# 案例三:查询orders集合中,id大于5000的文档共有多少个
db.orders.find({_id:{$gt:5000}}).count()

 2.13、去重查询

# 语法
db.集合名称.distinct('字段')

# 案例
user集合中按照age去重查询

 2.14、返回指定字段

# 语法
db.集合名称.find({条件},{name:1,age:1})
参数2: 1返回、0不返回  注意:1和0不能同时使用
# 案例一:查询所有
db.user.find({},{})

# 案例二:返回name字段,注意默认情况下,_id是唯一标识,会自动返回
db.user.find({},{name:1})

# 案例三:_id不要返回,其他字段都返回
db.user.find({},{_id:0})

 

# 案例四:_id和age不要返回,其他字段都返回
db.user.find({},{_id:0,age:0})

# 案例五、_id不返回,name返回
db.user.find({},{_id:0,name:1})

 

# 案例六(错误演示):name返回,age不返回
db.user.find({},{age:0,name:1})

 

三、删除

3.1、删除所有

# 语法
db.集合名称.remove({})

# 案例:删除user集合中所有的文档
db.user.remove({})

3.2、按条件删除

# 语法(适用于MongoDB2.6以后的版本)
db.集合名称.remove(
   <query>,
   {
     justOne: <boolean>,
     writeConcern: <document>
   }
)
参数说明:
    query :(可选)删除的文档的条件。
    justOne : (可选)如果设为 true 或 1,则只删除一个文档,如果不设置该参数,或使用默认值     false,则删除所有匹配条件的文档。
    writeConcern :(可选)抛出异常的级别。

 3.2.1、根据id删除文档

# 案例:删除user集合中id为10的文档(这里的id是创建文档时指定的id)

db.user.remove({"_id":10})

# 案例:删除user集合中id为 ObjectId("64770bd69e8658a4223033b4")的文档,说明:此id为Mongo自动生成的id
db.user.remove({"_id":"64770bd69e8658a4223033b4"})

 

 3.2.2、根据字段名称删除所有符合条件的文档

# 往user集合中出入age相同的三条数据进行测试
db.user.insert(
	[
		{
			"name":"张三",
			"age":23
		},
		{
			"_id":2,
			"name":"李四",
			"age":23
		},
		{
			"_id":3,
			"name":"王五",
			"age":23
		}
	]
)

# 删除age为23的文档记录
db.user.remove({"age":23})

  

四、更新文档

4.1、update更新

# 语法
db.集合名称.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)

参数说明:
query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。

 4.1.1、数据初始化

# 数据初始化
1、清空user集合中所有的数据
db.user.remove({})

2、数据初始化
for (let i = 0; i < 10; i++) {
	db.user.insert({"_id":i+1,"name":"李白","age":20+i});
}
db.user.insert({"_id":11,"name":"李太白","age":35})

3、当前user集合中的文档结构
db.user.find()

4.1.2、将id为11的文档,age修改为30

db.user.update({"_id":11},{"age":30})

 

 4.1.3、保留原始更新

# 案例
db.user.update({"_id":11},{$set:{"name":"李太白","age":30,"likes":["电视","读书","美女"]}})

# 案例
db.user.update({"_id":11},{$set:{"likes":["电视","读书","美女","吸烟","喝酒","烫头"]}})

 4.1.4、批量更新(保留原始更新&更新条件存在)

# 批量将name为李白的文档,年龄统一修改为24
db.user.update({"name":"李白"},{$set:{"age":24}},{multi:true})

 4.1.5、批量更新(保留原始更新&更新条件不存在,upsert为默认值)

# 批量更新name为杜甫的文档,将年龄统一修改为25
db.user.update({"name":"杜甫"},{$set:{"age":25}},{multi:true})

 4.1.6、批量更新(保留原始更新&更新条件不存在,upsert为true)

# 批量更新name为杜甫的文档,将年龄统一修改为25
db.user.update({"name":"杜甫"},{$set:{"age":25}},{multi:true,upsert:true})

说明:upsert设置为true,当匹配不到文档时,将会插入一条新文档

4.2、save更新

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。