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中的类似语句
    等于 {:} db.mycol.find({"by":"tutorials point"}).pretty() where by = 'tutorials point'
    小于 {:{$lt:}} db.mycol.find({"likes":{$lt:50}}).pretty() where likes < 50
    小于等于 {:{$lte:}} db.mycol.find({"likes":{$lte:50}}).pretty() where likes <= 50
    大于 {:{$gt:}} db.mycol.find({"likes":{$gt:50}}).pretty() where likes > 50
    大于等于 {:{$gte:}} db.mycol.find({"likes":{$gte:50}}).pretty() where likes >= 50
    不等于 {:{$ne:}} 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数据库中可用。超级账号,超级权限

你可能感兴趣的:(Mongodb总结)