Mongo的常用的相关语法

Mongod的条件操作符

$gt -------- greater than  >
$gte --------- gt equal  >=
$lt -------- less than  <
$lte --------- lt equal  <=
$ne ----------- not equal  !=
$eq  --------  equal  =

根据时间段去查询数据

db.getCollection('interface_log').find({type:"wms.csmtecaccexam.updateID",created:{"$lte":ISODate("2019-01-01 00:18:24.986Z")}})

IN 查询

db.getCollection('interface_log_body').find({"_id":{"$in":[ObjectId("5e1fa782cbb55107c6298ce0"),ObjectId("5e1fa782cbb55107c6298ce2")]}})

IN AND 字段

db.getCollection('interface_log_body').find({"_id":{"$in":[ObjectId("5e1fa782cbb55107c6298ce0"),ObjectId("5e1fa782cbb55107c6298ce2")]},"type":"wms.csmtecaccexam.updateID"})

按照字段查询

db.getCollection('interface_log').find({"type":"wms.csmtecaccexam.updateID"})

模糊查询

select * from interface_log where userName like '%A%'db.getCollection('interface_log').find({"type":/311902134280002/})

半模糊查询

select * from interface_log where userName like 'A%'db.interface_log.find({userName :/^A/})

正则表达式查询

db.posts.find({post_text:{$regex:"runoob"}})
即等于以下查询语句db.posts.find({post_text:/runoob/})

扩展

指定返回那些列(键):

select name, skills from users;db.users.find({}, {'name' : 1, 'skills' : 1});
补充说明: 第一个{} 放where条件 第二个{} 指定那些列显示和不显示 (0表示不显示 1表示显示)

where条件:

1.简单的等于:

select name, age, skills from users where name = 'hurry';db.users.find({'name' : 'hurry'},{'name' : 1, 'age' : 1, 'skills' : 1});

2.使用and

select name, age, skills from users where name = 'hurry' and age = 18;db.users.find({'name' : 'hurry', 'age' : 18},{'name' : 1, 'age' : 1, 'skills' : 1});

3.使用or

select name, age, skills from users where name = 'hurry' or age = 18;db.users.find({ '$or' : [{'name' : 'hurry'}, {'age' : 18}] },{'name' : 1, 'age' : 1, 'skills' : 1});

4.<, <=, >, >= ($lt, $lte, $gt, $gte )

select * from users where age >= 20 and age <= 30;db.users.find({'age' : {'$gte' : 20, '$lte' : 30}});

5.使用in, not in ($in, $nin)

select * from users where age in (10, 22, 26); db.users.find({'age' : {'$in' : [10, 22, 26]}});

6.匹配null

select * from users where age is null;db.users.find({'age' : null);

7.like (mongoDB 支持正则表达式)

select * from users where name like "%hurry%";db.users.find({name:/hurry/});select * from users where name like "hurry%";db.users.find({name:/^hurry/});

8.使用distinct

select distinct (name) from users;db.users.distinct('name');

9.使用count

select count(*) from users;db.users.count();

10.数组查询 (mongoDB自己特有的)

如果skills是 ['java','python']db.users.find({'skills' : 'java'}); 该语句可以匹配成功

$all

db.users.find({'skills' : {'$all' : ['java','python']}}) skills中必须同时包含java 和 python

$size

db.users.find({'skills' : {'$size' : 2}}) 遗憾的是$size不能与$lt等组合使用

$slice

db.users.find({'skills' : {'$slice : [1,1]}})传送门搬运工

修改语句:

db.getCollection('interface_log').update({"_id":new ObjectId("5e1fce2dcbb55107c629915b")},{$set:{"status":999}})
两个参数分别是偏移量和返回的数量

根据条件删除集合

db.getCollection('interface_log_body').remove({created:{"$gte":ISODate("2019-05-25 00:18:24.986Z")}})db.getCollection('interface_log').remove({"created":{"$lt":ISODate("2019-10-19 23:0:0")}})

删除所有

db.getCollection('interface_log_body').remove({})db.getCollection('interface_log_body').drop()

查看集合状态

db.getCollection('files.files').stats()image

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值