MongoDB

启动

#后台启动
D:\software\MongoDB\Server\3.0\bin>mongod --dbpath D:\software\MongoDB\Server\3.0\data\db

交互式 mongo shell
D:\software\MongoDB\Server\3.0\bin>mongo 127.0.0.1:27017
MongoDB shell version: 3.0.15
connecting to: 127.0.0.1:27017/test
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
        http://docs.mongodb.org/
Questions? Try the support group
        http://groups.google.com/group/mongodb-user
> use test
switched to db test
> db.users.findOne()
null
>db.runCommand( { create: "T_USER_INFO" } )
{ "ok" : 1 }
> show dbs
local  0.078GB
test   0.078GB
> use MIDDLE_PLATFORM
switched to db MIDDLE_PLATFORM
> db.T_USER_INFO.insert({x:1});
WriteResult({ "nInserted" : 1 })
>

#帮助 
help
#显示使用的数据库 
db
#切换数据库 
use <database>
#列出所有数据库 
show dbs

#可以直接切换到一个不存在的数据库,当第一个向该数据库存储数据时,MongoDB会创建这个数据库。
创建MIDDLE_PLATFORM数据库,并且创建T_USER_INFO集合
use MIDDLE_PLATFORM
db.T_USER_INFO.insert({x:1});

#如果集合名称包含空格,-字符,或者以数字开头,那么可以使用db['collection']方式访问集合,例如
db["3test"].find()
db.getCollection("3test").find()
mongo --eval 运行一段脚本
D:\software\MongoDB\Server\3.0\bin> mongo --eval "db.version()"
D:\software\MongoDB\Server\3.0\bin> mongo  --eval "db.T_USER_INFO.find().forEach(printjson)"
关于mongo与mongod的区别

mongod是处理MongoDB系统的主要进程。它处理数据请求,管理数据存储,和执行后台管理操作。当我们运行mongod命令意味着正在启动MongoDB进程,并且在后台运行。

mongo是一个命令行工具用于连接一个特定的mongod实例。当我们没有带参数运行mongo命令它将使用默认的端口号和localhost连接

用户 权限

你要为数据库MIDDLE_PLATFORM,添加具有dbOwner角色的用户test_02,那么就进行以下操作
use MIDDLE_PLATFORM

db.createUser(  
    {  
      user: "test_02",  
      pwd: "test_02",  
      roles: [{role: "dbOwner", db: "MIDDLE_PLATFORM"}]  
    }  
  )
  
  #授权用户(在当前数据库内)
  db.auth("test_02", "test_02")
  
D:\software\MongoDB\Server\3.0\bin>mongo 10.0.23.70:27017/MIDDLE_PLATFORM -u test_02 -p test_02 

这里顺便记录下mongodb的用户角色权限
user:用户名
pwd:密码
roles:指定用户的角色,可以用一个空数组给新用户设定空角色;在roles字段,可以指定内置角色和用户定义的角色。role里的角色可以选:

  Built-In Roles(内置角色):
    1. 数据库用户角色:read、readWrite;
    2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
    3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
    4. 备份恢复角色:backup、restore;
    5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
    6. 超级用户角色:root 
    // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)
    7. 内部角色:__system

具体角色:

Read:允许用户读取指定数据库
readWrite:允许用户读写指定数据库
dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile(没有读写权限)
userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root:只在admin数据库中可用。超级账号,超级权限。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值