Mongodb总结

Mongodb总结

简介

准备工作

安装Mongodb

windows版从官网下载安装文件一路OK即可

启动服务

连接服务

命令窗口执行 mongo host:portmongo host:port/dbNamemongo host:port/dbName -u user -p pwd 即可

数据库操作

创建数据库

  • 语法:use DATABASE_NAME,如果数据库不存在,则创建数据库,否则切换到指定数据库, show dbs 命令可查看所有数据库。几乎对数据库的所有操作都要先使用 use dbName 来切换数据库后再进行操作
    例:
    > use test
    switched to db test
    > db
    test
    > show dbs
    admin  0.000GB
    local  0.000GB
    test   0.000GB
    

删除数据库

  • 语法:db.dropDatabase(),先使用use命令切换到待删除数据库后使用该命令可删除相应数据库。
    例:
    > use test
    switched to db test
    > db
    test
    > db.dropDatabase()
    > show dbs
    admin  0.000GB
    local  0.000GB
    

创建集合

  • 语法:db.createCollection(name, options),在该命令中,name 是所要创建的集合名称。options 是一个用来指定集合配置的文档。
  • show collections命令可以查看该数据库下所有的集合。
    例:
    > use MyBlog
    switched to db MyBlog
    > db.createCollection('newcol')
    { "ok" : 1 }
    > show collections
    blog
    newcol
    users
    

删除集合

  • 语法:db.collectionName.drop(),其中collectionName为所要删除的集合的名称
    例:
    > db.newcol.drop()
    true
    > show collections
    blog
    users
    

查询文档

  • 语法:db.collectionName.find([param])[.pretty()],其中collectionName为要查询的集合名称,param为查询条件,如果不设置param,即 db.collectionName.find() 用来查询出全部文档,而pertty()方法指返回格式化的数据。
    例:
    >db.blog.find().pretty()
    /* 1 */
    {
    "_id" : ObjectId("59e017c497c02061aee8288a"),
    "title" : "first blog",
    "content" : "this is content for first blog",
    "author" : "ever",
    "createTime" : ISODate("2017-10-13T01:32:52.861Z")
    }
    
    /* 2 */
    {
    "_id" : ObjectId("59e0180197c02061aee8288b"),
    "title" : "second blog",
    "content" : "this is content for second blog",
    "author" : "john",
    "createTime" : ISODate("2017-10-13T01:33:53.297Z")
    }
    
  • 查询条件设置:
    操作 格式 范例 RDBMS中的类似语句
    等于 {<key>:<value>} db.mycol.find({"by":"tutorials point"}).pretty() where by = 'tutorials point'
    小于 {<key>:{$lt:<value>}} db.mycol.find({"likes":{$lt:50}}).pretty() where likes < 50
    小于等于 {<key>:{$lte:<value>}} db.mycol.find({"likes":{$lte:50}}).pretty() where likes <= 50
    大于 {<key>:{$gt:<value>}} db.mycol.find({"likes":{$gt:50}}).pretty() where likes > 50
    大于等于 {<key>:{$gte:<value>}} db.mycol.find({"likes":{$gte:50}}).pretty() where likes >= 50
    不等于 {<key>:{$ne:<value>}} db.mycol.find({"likes":{$ne:50}}).pretty() where likes != 50
    例:只查询author为ever的文档
    > db.blog.find({"author":"ever"}).pretty()
    
  • and条件设置:
    在 find() 方法中,如果传入多个键,并用逗号(,)分隔它们,那么 MongoDB 会把它看成是 AND 条件。AND 条件的基本语法格式为:
    db.collectionName.find({key1:value1, key2:value2}).pretty()

    db.collectionName.find({$and:[{key1:value1},{key2:value2}]})
    例:查询author为"ever"并且title为"second blog"的所有文档
    > db.blog.find({"author":"ever","title":"second blog"})
    或
    > db.blog.find({$and:[{"author":"ever"},{"title":"second blog"}]})
    
  • or条件设置:
    语法:db.mycol.find({$or:[{key1: value1}, {key2:value2}]}).pretty(),类似于and的语法

插入文档

MongoDB 使用 insert() 或 save() 方法向集合中插入文档,

  • 语法:db.COLLECTION_NAME.insert(document),同样的要先使用use切换到相应数据库。如果不指定 _id 字段 save() 方法类似于 insert() 方法。如果指定 _id 字段,则会更新该 _id 的数据。
    例:
    > db.person.insert({"name":"ever","age":18})
    Inserted 1 record(s) in 41ms
    > db.person.find()
    /* 1 */
    {
        "_id" : ObjectId("59de30103a2fba4b96f0ccb9"),
        "name" : "ever",
        "age" : 18.0
        }
    

更新文档

MongoDB 中的 update() 与 save() 方法都能用于更新集合中的文档。update() 方法更新已有文档中的值,而 save() 方法则是用传入该方法的文档来替换已有文档。

  • save():传入新的完整的文档来覆盖现有文档,需要包含_id字段
    例:
    >db.blog.save({"_id":"ObjectId(5983548781331adf45ec5)","title":"firstblog"})
    
  • update():db.COLLECTION_NAME.update(SELECTIOIN_CRITERIA, UPDATED_DATA)
    例:将author为"jack"并且title为"third blog"的文档的author字段更新为"ever"
    > db.blog.update({author:"jack",title:"third blog"},{$set:{author:"ever"}})
    Updated 1 existing record(s) in 98ms
    

删除文档

  • 语法:db.COLLECTION_NAME.remove(DELLETION_CRITTERIA[,justone]),其中justone参数为可选,表示是否只删除一条文档,1表示是,不赋值默认为否。(注:database和collection的删除都是用drop方法,并且无参数,文档删除用remove方法且有参数)。
    例:新增一条文档,并删除之
    > db.blog.insert({title:"seventh blog",content:"this is content for seventh blog",author:"sophia",createTime:new Date()})
    Inserted 1 record(s) in 86ms
    > db.blog.remove({author:"sophia",title:"seventh blog"})
    Removed 1 record(s) in 87ms
    

权限管理

用户管理

以上所有操作都不需要用户认证,任何人都可以连接并操作数据库,显然是很不安全的,需要为数据库添加用户并进行用户权限控制,基本操作步骤:创建管理员账号->登录管理员账号->创建普通用户->登录普通用户。具体如下:

  1. 创建管理员账号:
    MongoDB初始是没有管理员或默认账号的,需要自行添加,过程如下:
    • 连接服务器:mongo host/port/db
      > mongo localhost:27017
      MongoDB shell version v3.4.9
      connecting to: mongodb://127.0.0.1:27017
      MongoDB server version: 3.4.9
      
    • 切换到admin库(因为所有用户信息保存在admin库)并使用 db.createUser 方法创建管理员账号:
      > use admin
      switched to db admin
      > db.createUser(
          {
          user: "admin",
          pwd: "123456",
          roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
          })
      Successfully added user: {
          "user" : "admin",
          "roles" : [
                  {
                      "role" : "userAdminAnyDatabase",
                      "db" : "admin"
                  }
              ]
          }
      > show users
      {
          "_id" : "admin.admin",
          "user" : "admin",
          "db" : "admin",
          "roles" : [
              {
                      "role" : "userAdminAnyDatabase",
                      "db" : "admin"
              }
          ]
      }
      
    • 开启权限认证
      在 c:\data\db\conf\mongodb.conf 配置文件中添加一行: auth=true 即可开启权限认证,重新连接数据库测试,如下提示没有认证则表示开启认证成功
      > show dbs
      2017-10-16T10:01:22.637+0800 E QUERY    [thread1] Error: listDatabases failed:{
      "ok" : 0,
      "errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }",
      "code" : 13,
      "codeName" : "Unauthorized"
      } :
      
  2. 登录管理员账户:
    切换到admin数据库并使用 db.auth(user,pwd) 方法登录,返回1表示登录成功
    > db.auth('admin','123456')
    1
    
  3. 创建普通用户:
    切换到待创建普通用户的数据库并使用 db.createUser 方法创建普通账号:
    > db.createUser({user:"rascalquan",pwd:"123456",roles:[{role:"readWrite", db: "mydb"}]})
    
  4. 登录普通用户:
    使用 db.auth(user,pwd) 登录数据库
    > db.auth('rascalquan','123456')
    1
    

至此,可以使用rascalquan账号操作mydb数据库了。

修改用户密码

  • 语法:db.changeUserPassword('user','newPwd');

角色管理

MongoDB内置以下角色:

  • Read:允许用户读取指定数据库
  • readWrite:允许用户读写指定数据库
  • dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
  • userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
  • clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
  • readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
  • readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
  • userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
  • dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
  • root:只在admin数据库中可用。超级账号,超级权限
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,916评论 2 89
  • 安装 mongodb服务: sudo service mongod/mongodb start sudo serv...
    末版车阅读 585评论 0 0
  • 涨姿势 1.MySQL与Mongo中的一些概念对比: 基本语法规则 1.DDL语法(操作数据库及表的结构) ---...
    Cinque_Peng阅读 429评论 0 0
  • 学习《MongoDB 权威指南·第2版》的笔记,结合 MongoDB 官方最新文档(v3.6),简单记录一些概念、...
    小鱼爱小虾阅读 6,056评论 0 5
  • 版本3.6.x 配置 windows建议安装service方式,省的每次通过命令行启动server端。 对比mys...
    飞凡的陀螺阅读 493评论 0 0