MongoDB基本命令总结

其实一直想整理下我常使用的MongoDB数据库的一些操做命令,终于有时间了~mongodb

MongoDB是一种开源的,免费的非关系型数据库(NoSql),不存在表、记录等概念,与一般的关系型数据库有些差别:数据库

  • MongoDB里的集合可类比成关系数据库中的表,集合没有固定的结构,这意味着你在对集合能够插入不一样格式和类型的数据,但一般状况下咱们插入集合的数据都会有必定的关联性。集合存储在数据库中。
  • MongoDB里的文档可类比成关系型数据库中表中的字段,文档主要存储在集合中,mongodb将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档相似于 JSON 对象。字段值能够包含其余文档,数组及文档数组。

如下是一些经常使用命令数组

1、数据库数据结构

一、查看全部数据库:show dbs            ui

二、切换数据库:use  DATABASE_NAME         # 若是数据库不存在,则建立数据库spa

三、删除数据库:db.dropDatebase()                3d

 

2、集合对象

一、查看全部的集合:show collections 或者show tables         blog

二、建立mongotest集合:排序

  a、   db.creatCollection("mongotest")           # 建立集合

      b、   db.mycollections.insert({"name":"嗯哼~"})             # 在MongoDB中,当你插入一些文档时,MongoDB会自动建立集合

 

3、文档

一、插入文档:db.mycollections.insert()  或者 db.mymycollections.save()          

若是不指定 _id 字段 save() 方法相似于 insert() 方法。若是指定 _id 字段,则会更新该 _id 的数据。

例:

 

 

二、查找文档:db.mycollections.find()  

db.mycollections.find().pretty()       # 查找所有文档,按格式输出

db.mycollections.findOne()             # findOne是按照_id正序排列,没有查询条件,查找第一个被插入的数据

 例:       

 

 其余相关查询条件语法以下:

  • 小于:语法为 {<key>:{$lt:<value>}},例 :db.mycollections.find({"age":{$lt:19}})
  • 小于或等于:{<key>:{$lte:<value>}},例 :db.mycollections.find({"age":{$lte:19}})
  • 大于:{<key>:{$gt:<value>}},例 :db.mycollections.find({"age":{$gt:19}})
  • 大于等于:{<key>:{$gte:<value>}},例 :db.mycollections.find({"age":{$gte:19}}) 
  • 不等于:{<key>:{$ne:<value>}} ,例 :db.mycollections.find({"age":{$ne:18}})

 

三、更新命令:db.mycollections.update()         

例:将上面王红年龄从18岁改成19岁,操做命令为:db.mycollections.update({"name" : "王红"},{$set:{"age":"19"}})

 
 
四、 删除文档: db.mycollections.remove()          
例:
一、删除“张三”,操做命令为:db.mycollections.remove({"name":"张三"})  
二、插入多个姓名为“张三”的人,删除找到的第1条“张三”,操做命令为:db.mycollections.remove({"name":"张三"},1)      #  1,justOne参数

三、插入多个姓名为“张三”的人,删除找到的前2条“张三”,操做命令为:

    db.mycollections.remove({"_id" : {$in: [ObjectId("5b86b20c873007ee4d98c1e6"), ObjectId("5b86b20e873007ee4d98c1e7")]}})



 4、其余命令

一、查询过滤

  db.mycollections.find({"name":"张三"},{"age":1,_id:0})       #  1表示显示name,0表示不显示_id.

二、limit()

      若是你须要在MongoDB中读取指定数量的数据记录,可使用MongoDB的Limit方法,limit()方法接受一个数字参数,该参数指定从MongoDB中读取的记录条数。

      db.mycollectons.find().limit(2)          # 只显示2个文档

三、skip()

  除了可使用limit()方法来读取指定数量的数据外,还可使用skip()方法来跳过指定数量的数据,skip方法一样接受一个数字参数做为跳过的记录条数。
  db.mycollections.find({},{"name":1,_id:0}).limit(1).skip(1)     # 只显示第二个文档
 
四、sort()
  MongoDB使用sort()方法对数据进行排序,sort()方法能够经过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而-1是用于降序排列。
  db.mycollections.find().sort({age:1})                    # 文档按照age,升序排列
相关文章
相关标签/搜索