MongoDb入门

基础概念

SQLMongoDB描述
databasedatabase数据库
tablecollection表/集合
rowdocument记录/文档
columnfield字段/域
indexindex索引
primary keyprimary key主键(MongoDB自动将_id字段设置为主键)

基础命令

命令描述实例
use database_name建库use test
db.dropDatabase()删库
show dbs查看所有库
db.createCollection(name, options)建集合db.createCollection("user")
db.COLLECTION_NAME.drop()删集合db.user.drop()
db.COLLECTION_NAME.insert(document)插入文档db.user.insert({name:"tom"})自动创建集合
db.COLLECTION_NAME.update(<query>,<update>,{upsert: <boolean>,multi: <boolean>,writeConcern: <document>})更新文档db.user.update({name:"tom"},{name:"Jerry"})
db.COLLECTION_NAME.save(<document>, {writeConcern: <document>})替换文档db.user.save({_id:ObjectId("5e130a765718000023006d96"),name:"jerry",age:23})
db.COLLECTION_NAME.remove(<query>, {justOne: <boolean>,writeConcern: <document>})删除文档db.user.remove({name:"jerry"})
db.COLLECTION_NAME.deleteOne(<query>)删除一个文档db.user.deleteOne({name:"jerry"})
db.COLLECTION_NAME.deleteMany(<query>)删除多个文档db.user.deleteMany({age:21})
db.COLLECTION_NAME.find(<query>,<projection>)查询文档db.user.find({age:{$lt:21}})
db.COLLECTION_NAME.findOne(<query>,<projection>)查询一个文档db.user.findOne({age:21})

更新文档命令

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

替换文档命令

  • document : 文档数据。
  • writeConcern :可选,抛出异常的级别。

删除文档命令

  • query :(可选)删除的文档的条件。
  • justOne : (可选)如果设为 true 或 1,则只删除一个文档,如果不设置该参数,或使用默认值 false,则删除所有匹配条件的文档。
  • writeConcern :(可选)抛出异常的级别。

查询文档命令

  • query :可选,使用查询操作符指定查询条件
  • projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。
  • and和or

db.user.find({"age": {$gt:50}, $or: [{"name": "tom"},{"name": "jerry"}]}).pretty()
等价于select * from user where age > 50 and (name=‘tom’ or name=‘jerry’)

  • 基础操作符
操作格式
等于{<field>:<value>}
小于{<field>:{$lt:<value>}}
小于或等于{<field>:{$lte:<value>}}
大于{<field>:{$gt:<value>}}
大于或等于{<field>:{$gte:<value>}}
不等于{<field>:{$ne:<value>}}
  • $type操作符
类型数字备注
Double1
String2
Object3
Array4
Binary data5
Undefined6已废弃。
Object id7
Boolean8
Date9
Null10
Regular Expression11
JavaScript13
Symbol14
JavaScript(with scope)15
32-bit integer16
Timestamp17
64-bit integer18
Min key255Query with -1.
Max key127

db.user.find({"name" : {$type : 2}})db.user.find({"name" : {$type : 'string'}})

  • find子句
方法名备注实例
pretty()格式化查询结果db.user.find().pretty()
limit()读取指定数量的数据记录db.user.find().limit(1)
skip()跳过指定数量的数据db.user.find().skip(2)不查询前2条文档
sort({FIELD:1/-1})排序db.user.find().sort({age:-1})按age倒序

其他命令

  • db.repairDatabase()可用于回收磁盘空间
  • db.COLLECTION_NAME.createIndex(keys, options)创建索引
参数类型备注
backgroundBoolean建索引过程会阻塞其它数据库操作,background可指定以后台方式创建索引,即增加 “background” 可选参数。 “background” 默认值为false。
uniqueBoolean建立的索引是否唯一。指定为true创建唯一索引。默认值为false.
namestring索引的名称。如果未指定,MongoDB的通过连接索引的字段名和排序顺序生成一个索引名称。
dropDupsBoolean3.0+版本已废弃。在建立唯一索引时是否删除重复记录,指定 true 创建唯一索引。默认值为 false.
sparseBoolean对文档中不存在的字段数据不启用索引;这个参数需要特别注意,如果设置为true的话,在索引字段中不会查询出不包含对应字段的文档.。默认值为 false.
expireAfterSecondsinteger指定一个以秒为单位的数值,完成 TTL设定,设定集合的生存时间。
vindex version索引的版本号。默认的索引版本取决于mongod创建索引时运行的版本。
weightsdocument索引权重值,数值在 1 到 99,999 之间,表示该索引相对于其他索引字段的得分权重。
default_languagestring对于文本索引,该参数决定了停用词及词干和词器的规则的列表。 默认为英语
language_overridestring对于文本索引,该参数指定了包含在文档中的字段名,语言覆盖默认的language,默认值为 language.

db.user.createIndex({age:1, name:-1},{background: true})age正序索引,name倒序索引

  • db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)聚合
表达式描述实例
$sum计算总和。db.user.aggregate([{$group : {_id : "$dept", num_tutorial : {$sum : "$age"}}}])
$avg计算平均值db.user.aggregate([{$group : {_id : "$dept", num_tutorial : {$avg : "$age"}}}])
$min获取集合中所有文档对应值得最小值。db.user.aggregate([{$group : {_id : "$dept", num_tutorial : {$min : "$age"}}}])
$max获取集合中所有文档对应值得最大值。db.user.aggregate([{$group : {_id : "$dept", num_tutorial : {$max : "$age"}}}])
$push在结果文档中插入值到一个数组中。db.user.aggregate([{$group : {_id : "$dept", url : {$push: "$url"}}}])
$addToSet在结果文档中插入值到一个数组中,但不创建副本。db.user.aggregate([{$group : {_id : "$dept", url : {$addToSet : "$url"}}}])
$first根据资源文档的排序获取第一个文档数据。db.user.aggregate([{$group : {_id : "$dept", first_url : {$first : "$url"}}}])
$last根据资源文档的排序获取最后一个文档数据db.user.aggregate([{$group : {_id : "$dept", last_url : {$last : "$url"}}}])
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值