ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

2022MongoDB4-find正则等其它用法

2022-01-10 12:03:29  阅读:147  来源: 互联网

标签:name ObjectId age find 2022MongoDB4 正则 2022 id


1查看name包括着3个人的所有数据:

$in:可以使用索引,但是$nin不能使用索引,不能使用索引的尽量不用或者少用

> db.users.find({"name":{"$in":["bjsxt","admin","test"]}});

{ "_id" : ObjectId("61d93061adfe46eefd559f1f"), "name" : "bjsxt", "age" : 32 }
{ "_id" : ObjectId("61d93287adfe46eefd559f2b"), "name" : "admin", "age" : 32 }
{ "_id" : ObjectId("61db9b12d16a4f490e1c825c"), "name" : "test", "age" : 20, "gender" : "male", "hobbies" : [ "eat", "sleep" ], "phone" : 13512765432 }
> 

2查询name不包含这三个人的所有数据:

> db.users.find({"name":{"$nin":["bjsxt","admin","test"]}});

{ "_id" : ObjectId("61d8fa98aa30ebeedffca109"), "Python" : "FastAPI", "name" : "multi", "datenow" : "2022-01-08", "date" : "2022", "hobbies" : [ ] }
{ "_id" : ObjectId("61d8fafdaa30ebeedffca10b"), "Python" : "Django", "datenow" : "2022-01-08", "name" : "multi", "date" : "2022", "age" : 1 }
{ "_id" : ObjectId("61d8fafdaa30ebeedffca10c"), "name" : "multi", "datenow" : "2022-01-08", "date" : "2022", "age" : 1 }
{ "_id" : ObjectId("61d932d3adfe46eefd559f30"), "age" : 30, "username" : "xiaohong" }
>

3判断字段类型$type:

> db.users.find({"gender":{"$type":"string"}});
{ "_id" : ObjectId("61db9b12d16a4f490e1c825c"), "name" : "test", "age" : 20, "gender" : "male", "hobbies" : [ "eat", "sleep" ], "phone" : 13512765432 }
> 
> 
#查询一个字段是不是整数类型
> db.users.find({"gender":{"$type":"number"}});
#查询一个字段是不是浮点类型
> db.users.find({"gender":{"$type":"double"}});
#查询一个字段是不是整数类型
> db.users.find({"age":{"$type":"int"}});
#判断hobbies是不是数组类型
> db.users.find({"hobbies":{"$type":"array"}});
{ "_id" : ObjectId("61d8fa98aa30ebeedffca109"), "Python" : "FastAPI", "name" : "multi", "datenow" : "2022-01-08", "date" : "2022", "hobbies" : [ ] }
{ "_id" : ObjectId("61db9b12d16a4f490e1c825c"), "name" : "test", "age" : 20, "gender" : "male", "hobbies" : [ "eat", "sleep" ], "phone" : 13512765432 }
> 

4$exists判断字段值是不是null:

#判断a存在
> db.users.find({"a":{"$exists":1}});
#判断a不存在
> db.users.find({"a":{"$exists":0}});
{ "_id" : ObjectId("61d8fa98aa30ebeedffca109"), "Python" : "FastAPI", "name" : "multi", "datenow" : "2022-01-08", "date" : "2022", "hobbies" : [ ] }
{ "_id" : ObjectId("61d8fafdaa30ebeedffca10b"), "Python" : "Django", "datenow" : "2022-01-08", "name" : "multi", "date" : "2022", "age" : 1 }
{ "_id" : ObjectId("61d8fafdaa30ebeedffca10c"), "name" : "multi", "datenow" : "2022-01-08", "date" : "2022", "age" : 1 }
{ "_id" : ObjectId("61d93061adfe46eefd559f1f"), "name" : "bjsxt", "age" : 32 }
{ "_id" : ObjectId("61d93287adfe46eefd559f2b"), "name" : "admin", "age" : 32 }
{ "_id" : ObjectId("61d932d3adfe46eefd559f30"), "age" : 30, "username" : "xiaohong" }
{ "_id" : ObjectId("61db9b12d16a4f490e1c825c"), "name" : "test", "age" : 20, "gender" : "male", "hobbies" : [ "eat", "sleep" ], "phone" : 13512765432 }
> 

5正则表达式:

^开头,$结束,.任意字符,*代表0或多个,+代表一个或多个,?代表0或1个
i:不区分大小写
m:多行查找

1)查询name值以a开头的数据:

#区分大小写查找
> db.users.find({"name":{"$regex":/^a.*/}});
#不区分大小写查找以a开头的数据(简写):
> db.users.find({"name":{"$regex":/^a.*/i}});
{ "_id" : ObjectId("61d93287adfe46eefd559f2b"), "name" : "Admin", "age" : 32 }
#不区分大小写查找以a开头的数据(全写)
> db.users.find({"name":{"$regex":/^a/,"$options":"im"}});
{ "_id" : ObjectId("61d93287adfe46eefd559f2b"), "name" : "admin", "age" : 32 }
> 

 

标签:name,ObjectId,age,find,2022MongoDB4,正则,2022,id
来源: https://www.cnblogs.com/tyjs09/p/15783835.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有