MongoDB的操作

查询包含ZY:

db.getCollection('cdaDocIdx').find({cdaType:"C0001",localId:/ZY/})

查询ZY开头:

db.getCollection('cdaDocIdx').find({cdaType:"C0001",localId:/^ZY/})

按条件组合删除:

db.getCollection('cdaDocIdx').remove({cdaType:"C0001",localId:/^ZY/,"createTime":{"$gt":ISODate("2022-08-01T00:00:00.303Z")}})

 

查询数量:

db.getCollection('cdadata_10.0.0.112').find().count();

例如查询ct>=2012.12.7 且et<=2012.12.7:可翻译为

"ct":{$gte:new Date(2012,11,7)},"et":{$lte:new Date(2012,11,7)}

db.xxxx.find({"ct":{"$gt":ISODate("2017-04-20T01:16:33.303Z")}}) // 大于某个时间

db.xxxx.find({"ct":{"$lt":ISODate("2017-04-20T01:16:33.303Z")}}) // 小于某个时间

db.xxxx.find({"$and":[{"ct":{"$gt":ISODate("2017-04-20T01:16:33.303Z")}},{"ct":{"$lt":ISODate("2018-12-05T01:16:33.303Z")}}]}) // 某个时间段

db.xxxx.find({"ct":{"$gte":ISODate("2017-04-20T01:16:33.303Z"),"$lte":ISODate("2018-12-05T01:16:33.303Z")}}) //某个时间段

模糊查找

db.getCollection('cda').find({"cdaXml":{$regex:/ZY012021010108.*/i}})

MongoDB.Driver  驱动的IMongoQuery,其中Query的设计很有意思。用法见下:

Query.All("name", "a", "b");//通过多个元素来匹配数组
Query.And(Query.EQ("name", "a"), Query.EQ("title", "t"));//同时满足多个条件
Query.EQ("name", "a");//等于
Query.Exists("type", true);//判断键值是否存在
Query.GT("value", 2);//大于>
Query.GTE("value", 3);//大于等于>=
Query.In("name", "a", "b");//包括指定的所有值,可以指定不同类型的条件和值
Query.LT("value", 9);//小于<
Query.LTE("value", 8);//小于等于<=
Query.Mod("value", 3, 1);//将查询值除以第一个给定值,若余数等于第二个给定值则返回该结果
Query.NE("name", "c");//不等于
Query.Nor(Array);//不包括数组中的值
Query.Not("name");//元素条件语句
Query.NotIn("name", "a", 2);//返回与数组中所有条件都不匹配的文档
Query.Or(Query.EQ("name", "a"), Query.EQ("title", "t"));//满足其中一个条件
Query.Size("name", 2);//给定键的长度
Query.Type("_id", BsonType.ObjectId );//给定键的类型
Query.Where(BsonJavaScript);//执行JavaScript
Query.Matches("Title",str);//模糊查询 相当于sql中like  -- str可包含正则表达式

 

posted on 2022-05-20 20:18  巍巍之道  阅读(58)  评论(0编辑  收藏  举报

导航