启动
#后台启动
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数据库中可用。超级账号,超级权限。