mongo 的crud操作&&mongo的数据聚合
2016-10-10 16:30
190 查看
插入insert
插入单个文档db.getCollection('users').insert({"name":"sasa"})
插入多个文档
db.getCollection('users').insert([{"name":"sasa"},{"sdsd":"sasa"}])
查询操作query
db.collection.find( , )用于查找满足过滤条件的Document
(投影)用于指定被找到的Document中需要返回哪些字段,用于限制网络中传输的数据的大小。投影的概念和关系数据库中的投影的概念基本是一致的。
得到users的所有的文档
db.getCollection('users').find()
查找sdsd的值为sasa的文档
db.getCollection('users').find({sdsd:"sasa"})
查找name的值为sasa和sasa1 的文档 $in
db.getCollection('users').find({name:{"$in":["sasa","sasa1"]}})
只显示name、time字段
db.getCollection('posts').find({},{name:1,time:1})
删除操作remove
db.getCollection('users').remove({name:"sasa"},{w:1})
更新操作update
$inc用法:{ $inc : { field : value } }意思对一个数字字段field增加value 只支持数据类型
db.getCollection('users').update({name:"sasa"},{$inc:{post:1}})
$set
用法:{ set : { field : value } }就是相当于sql的set field = value,全部数据类型都支持set
db.getCollection('users').update({sdsd:"sasa"},{$set:{sdsd:"sasa1"}})
$unset
用法:{ $unset : { field : 1} }顾名思义,就是删除字段了。实现的是删除一特定的字段
db.getCollection('users').update({"name":"sasa1"},{$unset:{"post":1}})
$push
用法:{ $push : { field : value } }把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。
db.getCollection('users').update({name:"sasa1"},{$push:{grade:1}})
第一次执行的时候会在name为”sasa1”的文档中新增加一个名字为grade的数组,并有有一个元素为1,
第二次执行的时候会在name为”sasa1”的文档中的数组grade增加一个元素。
$pushAll
用法:{ pushAll : { field : value_array } }同push,只是一次可以追加多个值到一个数组字段内。例:
db.getCollection('users').update({name:"sasa1"},{$pushAll:{grade:[2,3,4]}})
$addToset
用法:{ $addToSet : { field : value } }增加一个值到数组内,而且只有当这个值不在数组内才增加。
db.getCollection('users').update({name:"sasa1"},{$addToSet:{grade:[11,3]}})
会在grade这个数组里边新 增加一个新的数组,数组里边会有11和3这两个元素
$pop
删除数组内的一个值
用法:
删除最后一个值:{ pop : { field : 1 } }
删除第一个值:{pop : { field : -1 } }
db.getCollection('users').update({name:"sasa1"},{$pop:{grade:1}})
实现的是删除了刚才在grade中最后的新增加的那个数组
$pull
用法:$pull : { field : value } }从数组field内删除一个等于value值。
db.getCollection('users').update({name:"sasa1"},{$pull:{grade:4}})
会删除garde中的值为4 的所有元素
$pullAll
用法:{ pullAll : { field : value_array } }同pull,可以一次删除数组内的多个值。
db.getCollection('users').update({name:"sasa1"},{$pullAll:{grade:[3,4]}})
会删除grade中的所有的3和4
collection.count()
(1)count作用:简单统计集合中符合某种条件的文档数量。
使用方式:db.collection.count()或者db.collection.find().count()
参数说明:其中是用于查询的目标条件。如果出了想限定查出来的最大文档数,或者想统计后跳过指定条数的文档,则还需要借助于limit,skip。
举例:
db.collection.find().limit();
db.collection.find().skip();
db.getCollection('users').find().skip(2)
(2)distinct
作用:用于对集合中的文档针进行去重处理
使用方式:db,collection.distinct(field,query)
参数说明:field是去重字段,可以是单个的字段名,也可以是嵌套的字段名;query是查询条件,可以为空;
举例:
db.collection.distinct(“user”,{“age”:{$gt:28}});//用于查询年龄age大于28岁的不同用户名
db.getCollection('posts').distinct("name")
查询到所有文档中不同的名字,相当于给名字去重
相关文章推荐
- SSM框架CRUD操作&批量删除&批量追加数据(Oracle&MySQL数据库)
- MongoDB(6)数据聚合 & 管道操作
- 自动生成数据对象代码和CRUD操作的C#代码生成器
- Silverlight 2 (beta1)数据操作(1)——使用ASP.NET Web Service进行数据CRUD操作(上)
- 4.oracle表的管理(数据类型,表创建删除,数据CRUD操作)
- oracle表的管理(数据类型,表创建删除,数据CRUD 操作)
- Silverlight 2 (beta1)数据操作(4)——调用WCF进行数据CRUD操作
- Control study -> Drag拖放数据操作示例
- 【原创】SQL数据累计求和等聚合操作
- Silverlight ——使用LINQ to SQL进行数据CRUD操作(上)
- NHibernate&&Linq简单的CRUD操作
- 4.如何优化操作大数据量数据库(几十万以上数据)(如何选择聚合索引)
- Silverlight 2 (beta1)数据操作(2)——使用ASP.NET Web Service进行数据CRUD操作(下)
- [导入]Silverlight 2 (beta1)数据操作(3)——使用ADO.NET Data Service (Astoria)进行数据CRUD操作
- [导入]Silverlight 2 (beta1)数据操作(2)——使用ASP.NET Web Service进行数据CRUD操作(下)
- JavaScript操作cookie & Jquery跨域读取json数据
- 用string实现的一个完整的类,包含以下操作:重载运算符 > >,< < ,string模板类,fstream对二进制数据读写
- [导入]Silverlight 2 (beta1)数据操作(1)——使用ASP.NET Web Service进行数据CRUD操作(上)
- [导入]Silverlight 2 (beta1)数据操作(5)——使用LINQ to SQL进行数据CRUD操作(上)
- 如何优化操作大数据量数据库(几十万以上数据)(四。如何选择聚合索引)