版本:mongodb3.4。
User:
mongodb使用验证登录;默认不开启,mongod中使用--auth开启:
mongod -port=3000 --auth ;
基本方法:
db.createUser({ user:username, pwd:passwd, roles:[ {role: ‘ readWrite‘ , db : ‘db1‘} ] //定义这个用户对应db的权限。 }); db.updateUser(username,{ pwd:‘‘, roles:[] }) db.dropUser(username); db.changeUserPassword(username,newpswd);
具体roles:参见
在mongod开启验证前先在默认模式下,创建超级用户:
mongo:
use admin;
db.createUser({user : ‘myRoot‘ , pwd: ‘***‘ , roles: [ role:‘root‘ , db:‘admin‘ ] });
在创建好超级用户后,再开启mongod的验证模式,这样以后就能考靠这个超级用户来创建其他用户了。
登录mongod:
mongo -port=3000 -username=myRoot -password= *** -authenticationDataBase=admin
authenticationDataBase ,指定你登录的DataBase.
另一种方法:
mongo -port=3000;
use admin;
db.auth(‘myRoot‘,‘***‘);
登录后因为你是超级用户所以可以创建其它用户,并指定权限。
mongodb在用户登录时,使用明文传输数据。建议使用TSL。
Aggregate:
Instance:
db.test.aggregate([
{$match: {city: ‘shanghai‘ }}, //匹配城市是上海的人。
{$limit:5}, //只取5个document。
{$group:{_id:‘$sex‘ , ageAvg: {$avg:‘$age‘} }} //将这5个人按照性别分组,ageAvg获得他们的平均属性。
])
aggregate中的可用操作符是比较多,比如$project:
db.test.aggregate([ {$group:{id:‘$sex‘, ageArr: { $push : ‘$age‘}}} , {$project: {_id:‘$name‘, sumAge: { $reduce:{ input:‘$ageArr‘, initialVal: 0, in: [ ‘$$value‘ ,‘ $$this‘] //value指initialVal的值,this指遍历ageArr时的当前值。 } }}} ])
Mongodb笔记(三)user && aggregate && mapReduce
原文:http://www.cnblogs.com/ztwBlog/p/6282367.html