MongoDB 修改用户密码 2种方法

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

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
相关文章
|
7月前
|
存储 NoSQL 测试技术
在MongoDB建模1对N关系的基本方法
了解更多阿里云MongoDB的介绍
1662 2
在MongoDB建模1对N关系的基本方法
|
存储 监控 NoSQL
第4期 MongoDB配置用户名密码认证登录
MongoDB配置用户名密码认证登录
3455 0
|
7月前
|
NoSQL 关系型数据库 MySQL
深入了解 Python MongoDB 查询:find 和 find_one 方法完全解析
在 MongoDB 中,我们使用 find() 和 find_one() 方法来在集合中查找数据,就像在MySQL数据库中使用 SELECT 语句来在表中查找数据一样
136 1
|
2月前
|
NoSQL Java MongoDB
MongoDB Limit 与 Skip 方法
10月更文挑战第16天
41 3
|
6月前
|
NoSQL MongoDB 数据库
MongoDB 分页神器:limit() 和 skip() 方法详解
MongoDB 分页神器:limit() 和 skip() 方法详解
124 1
|
4月前
|
NoSQL Ubuntu MongoDB
在Ubuntu 16.04上安装和保护MongoDB的方法
在Ubuntu 16.04上安装和保护MongoDB的方法
42 1
|
NoSQL Linux MongoDB
MongoDB配置用户名和密码
MongoDB配置用户名和密码
663 0
|
6月前
|
NoSQL 安全 MongoDB
精准数据清理:掌握 MongoDB 删除集合的方法与最佳实践
精准数据清理:掌握 MongoDB 删除集合的方法与最佳实践
236 0
|
7月前
|
监控 NoSQL MongoDB
第5期 MongoDB配置用户名密码认证登录
第5期 MongoDB配置用户名密码认证登录
659 0
|
7月前
|
NoSQL MongoDB 数据库
MongoDB【部署 03】Windows系统安装mongodb并设置用户名密码(无需安装mongosh)及SpringBoot集成报错 Command failed with error 18
MongoDB【部署 03】Windows系统安装mongodb并设置用户名密码(无需安装mongosh)及SpringBoot集成报错 Command failed with error 18
628 0