MongoDB 修改用户密码 2种方法

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介:

mongodb的用户信息是存放在system.users表中的,修改密码不能直接更新表数据,这样的话,存到表里的密码是明文的,这就不对了。

1,错误做法,直接更新表

Java代码   收藏代码
  1. > db.system.users.update({"_id" : ObjectId("529e67553992b24438d5e315")},{"user":"tank2","readOnly" : false,"pwd":"123"})  
  2. > db.system.users.find();  
  3. "_id" : ObjectId("529e5f8474b4c660718a70f3"), "user" : "tank1""readOnly" : false"pwd" : "35dd47abff098f5b4f0b567db8edeac5" }  
  4. "_id" : ObjectId("529e67553992b24438d5e315"), "user" : "tank2""readOnly" : false"pwd" : "123" }  //这样就不对了  

 2,正确做法,利用db.addUser

Java代码   收藏代码
  1. > db.addUser('tank2','111')  
  2. {  
  3.     "_id" : ObjectId("529e6f1c8d95afd190add450"),  
  4.     "user" : "tank2",  
  5.     "readOnly" : false,  
  6.     "pwd" : "6b4334d2c97c526e6a11b2f9ce1996e0"  
  7. }  

有人会问,这个不是添加用户的方法吗。不错这是添加用户的方法,但是如果用户名相同,密码不同的话,就会更新密码。

3,正确做法,利用db.changeUserPassword

Java代码   收藏代码
  1. > db.changeUserPassword('tank2','test');    

 db的帮助

Java代码   收藏代码
  1. db.AddUser(username,password)  添加用户  
  2. db.auth(usrename,password)     设置数据库连接验证  
  3. db.cloneDataBase(fromhost)     从目标服务器克隆一个数据库  
  4. db.commandHelp(name)           returns the help for the command  
  5. db.copyDatabase(fromdb,todb,fromhost)  复制数据库fromdb---源数据库名称,todb---目标数据库名称,fromhost---源数据库服务器地址  
  6. db.createCollection(name,{size:3333,capped:333,max:88888})  创建一个数据集,相当于一个表  
  7. db.currentOp()                 取消当前库的当前操作  
  8. db.dropDataBase()              删除当前数据库  
  9. db.eval(func,args)             run code server-side  
  10. db.getCollection(cname)        取得一个数据集合,同用法:db['cname'] or  
  11. db.getCollenctionNames()       取得所有数据集合的名称列表  
  12. db.getLastError()              返回最后一个错误的提示消息  
  13. db.getLastErrorObj()           返回最后一个错误的对象  
  14. db.getMongo()                  取得当前服务器的连接对象get the server  
  15. db.getMondo().setSlaveOk()     allow this connection to read from then nonmaster membr of a replica pair  
  16. db.getName()                   返回当操作数据库的名称  
  17. db.getPrevError()              返回上一个错误对象  
  18. db.getProfilingLevel()         获取profile level  
  19. db.getReplicationInfo()        获得重复的数据  
  20. db.getSisterDB(name)           get the db at the same server as this onew  
  21. db.killOp()                    停止(杀死)在当前库的当前操作  
  22. db.printCollectionStats()      返回当前库的数据集状态  
  23. db.printReplicationInfo()        打印主数据库的复制状态信息  
  24. db.printSlaveReplicationInfo()        打印从数据库的复制状态信息  
  25. db.printShardingStatus()       返回当前数据库是否为共享数据库  
  26. db.removeUser(username)        删除用户  
  27. db.repairDatabase()            修复当前数据库  
  28. db.resetError()  
  29. db.runCommand(cmdObj)          run a database command. if cmdObj is a string, turns it into {cmdObj:1}  
  30. db.setProfilingLevel(level)    设置profile level 0=off,1=slow,2=all  
  31. db.shutdownServer()            关闭当前服务程序  
  32. db.version()                   返回当前程序的版本信息  

 表的帮助,格式,db.表名.help()

Java代码   收藏代码
  1. db.test.find({id:10})          返回test数据集ID=10的数据集  
  2. db.test.find({id:10}).count()  返回test数据集ID=10的数据总数  
  3. db.test.find({id:10}).limit(2) 返回test数据集ID=10的数据集从第二条开始的数据集  
  4. db.test.find({id:10}).skip(8)  返回test数据集ID=10的数据集从0到第八条的数据集  
  5. db.test.find({id:10}).limit(2).skip(8)  返回test数据集ID=1=的数据集从第二条到第八条的数据  
  6. db.test.find({id:10}).sort()   返回test数据集ID=10的排序数据集  
  7. db.test.findOne([query])       返回符合条件的一条数据  
  8. db.test.getDB()                返回此数据集所属的数据库名称  
  9. db.test.getIndexes()           返回些数据集的索引信息  
  10. db.test.group({key:...,initial:...,reduce:...[,cond:...]})    返回分组信息  
  11. db.test.mapReduce(mayFunction,reduceFunction,<optional params>)  这个有点像存储过程  
  12. db.test.remove(query)                      在数据集中删除一条数据  
  13. db.test.renameCollection(newName)          重命名些数据集名称  
  14. db.test.save(obj)                          往数据集中插入一条数据  
  15. db.test.stats()                            返回此数据集的状态  
  16. db.test.storageSize()                      返回此数据集的存储大小  
  17. db.test.totalIndexSize()                   返回此数据集的索引文件大小  
  18. db.test.totalSize()                        返回些数据集的总大小  
  19. db.test.update(query,object[,upsert_bool]) 在此数据集中更新一条数据  
  20. db.test.validate()                         验证此数据集  
  21. db.test.getShardVersion()                  返回数据集共享版本号  

 

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
3月前
|
NoSQL 关系型数据库 MySQL
深入了解 Python MongoDB 查询:find 和 find_one 方法完全解析
在 MongoDB 中,我们使用 find() 和 find_one() 方法来在集合中查找数据,就像在MySQL数据库中使用 SELECT 语句来在表中查找数据一样
65 1
|
8月前
|
SQL NoSQL Shell
MongoDB常用的操作-(find方法)
MongoDB常用的操作-(find方法)
139 0
|
NoSQL MongoDB 数据库
Mongodb的修改数据讲解|学习笔记
快速学习 Mongodb 的修改数据讲解
429 0
|
NoSQL Java MongoDB
MongoDB Limit与Skip方法
MongoDB Limit与Skip方法
55 0
|
存储 NoSQL JavaScript
使用TS封装操作MongoDB数据库的工具方法
使用TS封装操作MongoDB数据库的工具方法
|
NoSQL 关系型数据库 MySQL
SpringBoot高级篇MongoDB之修改基本使用姿势
本篇依然是MongoDB curd中的一篇,主要介绍document的更新,主要内容如下 常见类型成员的修改 数组类型成员的增删改 document类型成员的增删改
495 0
|
NoSQL MongoDB
MongoDB修改,删除文档踩坑记!
MongoDB修改,删除文档踩坑记!
79 0
|
NoSQL MongoDB
MongoDB实现Multi tenant的方法
MongoDB实现Multi tenant的方法
228 0
MongoDB实现Multi tenant的方法
|
NoSQL MongoDB
MongoDB修改文档
MongoDB修改文档 一、文档替换     文档替换其实在之前已经有讲过了,就是传入两个对象,第一个对象作为调节,第二个条件作为满足条件的文档修改的内容,例如:     db.test.
1673 0