设为首页 收藏本站
查看: 1302|回复: 0

[经验分享] Mongodb常用操作

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-5-13 08:37:26 | 显示全部楼层 |阅读模式
mongodb使用
安装mongodb,并启动mongodb后,基本操作:
1
2
3
4
show dbs; 显示数据库
show collections;显示当前数据库中的集合,类似mysql中数据库的表
show users; 显示用户
use <db name> 切换当前数据库,与mysql中一样



数据库常用命令:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
MongoDB没有创建数据库的命令,但有类似的命令,先运行use <db name> 命令,之后就做一些操作,如db.createCollection('user'),这样就可以创建一个数据库了。

删除当前使用的数据库: db.dropDatabase();

从指定的主机上克隆数据库: db.cloneDatabase('hostname/ip');
     
从指定的机器上复制指定的数据库到某个数据库 db.copyDatabase('mydb','temp','127.0.0.1:27017')

修复当前数据库: db.repairDatabase();

查看当前使用的数据库: db.getName() / db

显示当前db状态 db.stats()

当前db版本 db.version()

查看当前db的链接机器的地址 db.getMongo()



Collection集合常用命令:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
创建一个集合: db.createCollection('name', {capped:<Boolean>,autoIndexId:<Boolean>,size:<number>,max:<number>})
    name:是集合的名字,
    capped: 是否启用集合限制,如果启用需要制定一个限制条件,默认不启用,这个参数没有实际意义
    size:限制集合使用空间的大小,默认没有限制
    max:集合中最大条数限制,默认为没有限制
    autoIndexId: 是否使用id作为索引,默认使用(true/false)
    size 的优先级比max高
比如:
    1、db.createCollection('log') 没有任何的大小,数量限制,使用_id作为默认索引
    2、限制集合空间的大小:db.createCollection('log',{size:1024}) 或db.createCollection('log',{capped:true,size:1024}),限制空间大小为1M,如果超出1M,则会删除最早的记录
    3、限制集合的最大条数: db.createCollection('log',{max:1024}),创建一个名字为log集合,最大条数为1024,超过则会删除最早的一条记录,这个不能使用capped:true,否则会报错
    4、限制最大条数有限制使用空间大小,db.createCollection('log',{size:1024,max:1024})或 db.createCollection('log',{capped:true,size:1024,max:1024}) 限制集合最大使用空间为1M,最大条数为1024条
     
得到指定名称的集合 db.getCollection('one')

得到当前db的所有集合 db.getCollectionNames()

显示当前db所有集合索引的状态 db.printCollectionStats()



用户相关相关操作:
1
2
3
4
5
6
7
8
9
Mongodb用户和认证 权限总结:
新安装mongodb后开启MongoDB服务时不添加任何参数时,默认是没有权限验证的,登录的用户可以对数据库任意操作而且可以远程访问数据库。此时,mongodb默认有一个admin数据库,并且是空的,没有记录权限相关的信息。当admin.system.users一个用户都没有时,即使mongodb启动时添加了--auth参数,如果没有在admin数据库中添加用户,此时不进行任何认证还是可以做任何操作。直到admin.system.users中添加了一个用户。
需要注意的是:admin.system.users中将会保存比在其它数据库中设置的用户权限更大的用户信息,拥有超级权限,也就是说在admin中创建的用户可以对mongodb中的其他数据库数据进行操作。

1、mongodb系统中,数据库是由超级用户来创建的,一个数据库可以包含多个用户,一个用户只能在一个数据库下,不同数据库中的用户可以同名!
2、当admin.system.users一个用户都没有时,即使mongod启动时添加了--auth参数,如果没有在admin数据库中添加用户,此时不进行任何认证还是可以做任何操作(不管是否是以--auth 参数启动),直到在admin.system.users中添加了一个用户。
3、特定数据库比如DB1下的用户User1,不能够访问其他数据库DB2,但是可以访问本数据库下其他用户创建的数据!
4、不同数据库中同名的用户不能够登录其他数据库!比如DB1,DB2都有user1,以user1登录DB1后,不能够登录到DB2进行数据库操作!
5、在admin数据库创建的用户具有超级权限,可以对mongodb系统内的任何数据库的数据对象进行操作!



用户相关命令操作:

1
2
3
4
添加一个用户:db.addUser('name')或 db.addUser('username','passwd123',true) 添加用户,设置密码,是否为只读,默认为false
数据库认证、安全模式  db.auth('username','passwd')
显示当前所有用户: show users;
删除用户: db.removeUser('username')



集合查询:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
查询所有记录:
db.userInfo.find() 相当于:select * from userInfo;
默认每页显示20条记录,当显示不下的情况下,可以用it迭代命令查询下一页,it后面不要加;可以设置每页显示数据的大小,用DBQuery.shellBatchSize= 50;这样每页就显示50条记录了

查询去掉集合中的某列的重复数据
db.userInfo.distinct('name')  相当于:select distict name from userInfo;

查询age=xx的记录
db.userInfo.find({'age':22})

查询age>22的记录:
db.userInfo.find({age:{$gt:22}})  相当于:select * from userInfo where age >22;

查询age<22的记录:
db.userInfo.find({age:{$lt:22}})

查询age >= 25的记录
db.userInfo.find({age:{$gte:25}})

查询age <= 25的记录
db.userInfo.find({age:{$lte:25}})

查询age >= 23 并且 age <= 26
db.userInfo.find({age:{$gte:23,$lte:26}})

查询name中包含mongo的数据
db.userInfo.find({name: /mongo/}) 相当于:select * from userInfo where name like ‘%mongo%’;

查询name中以mongo开头的
db.userInfo.find({name:/^mongo/}) 相当于:select * from userInfo where name like ‘mongo%’;

查询指定列name,age数据:
db.userInfo.find({},{name:1,age:1}) 相当于:select name, age from userInfo;

当然name也可以用true或false,当用true的情况下,如例子一样的效果,如果为false就排除name,显示name以外的列的信息。
查询指定列name、age数据, age > 25
db.userInfo.find({age:{$gt:25}},{name:1,age:1})

查询name = zhangsan, age = 22的数据
db.userInfo.find({name:'zhangsan',age:22})

查询10条以后的数据
db.userInfo.find().skip(10)  相当于:select * from userInfo where id not in (selecttop 10 * from userInfo);

查询在5-10之间的数据
db.userInfo.find().limt(10).skip(5)
可用于分页,limit是pageSize,skip是第几页*pageSize

and 查询
db.userInfo({'name':'hurry','age':18},{'name':1,'age':1}) 相当于:select name,age from userInfo  where name='hurry'

or与查询
db.userInfo.find({$or: [{age:22},{age:25}]}) 相当于:select * from userInfo where age = 22 or age = 25;

使用in,not in ($in,$nin)
db.userInfo.find({'age':{$in:[10,22,26]}})  相当于:select * from users where age in (10, 22, 26);

与null匹配
db.userInfo.find({'age':null})

查询第一条数据:
db.userInfo.findOne() 相当于:selecttop 1 * from userInfo;
或:db.userInfo.find().limit(1)

查询某个结果集的记录条数:
db.userInfo.find({age:{$gte:25}}).count() 相当于:select count(*) from userInfo where age >= 25;

按照某列进行求和:
db.userInfo.find({sex:{$exists:true}}).count() 相当于select count(sex) from userInfo;



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
大于,小于,大于或等于,小于或等于
$gt:大于
$lt:小于
$gte:大于或等于
$lte:小于或等于

不等于:$ne

取模运算:$mod
db.userInfo.find({'a':{$mod:[10,1]}})

$all
$all 与$in类似,但是他需要匹配条件内所有的值:
如一个对象:{a:[1,2,3]}
这个条件可以匹配:db.userInfo.find(a:{$all:[2,3]})
但是这个条件就不行了,db.userInfo.find(a:{$all:[2,3,4]})

$size 是匹配数组内的元素数量的
如一个对像:{a:['foo']}
这个语句就可以匹配:db.userInfo.find({a:{$size:1}})
官网上说不能用来匹配一个范围内的元素,如果想找$size<5之类的,他们建议创建一个

$exists
$exists用来判断一个元素是否存在
如下:
db.userInfo.find({a:{$exists:true}}) 如果存在a就返回
db.userInfo.find({a:{$exists:false}}) 如果不存在元素a 就返回

$not取反
db.userInfo.find({'name':{$not:/acme.*corp/i}})

$type
$type基于bson type来匹配一个元素的类型,像是按照ID来匹配,bson类型和id对照表:



类型描述类型值
Double
1
String2
Object3
Array4
Binary data5
Object id
7
Boolean8
Date9
Null10
Regular expression                         11
JavaScript code
13
Symbol14
JavaScript code with scope15
32-bit integer16
Timestamp
17
64-bit integer18
Min key
255
Max key127
使用如下:
1
2
db.userInfo.find({a:{$type:2}}) 如果是字符串即:string就返回a
db.userInfo.find({a:{$type:16}}) 如果是int类型,就返回a



正则表达式
1
2
mongo支持正则表达式,如
db.userInfo.find({name:/acme.*corp/i}) 后面i的意思是区分大小写



索引:
1
2
3
4
5
6
7
8
9
10
11
12
13
创建索引:
db.userInfo.ensureIndex({name:1})
db.userInfo.ensureIndex({name:1,ts:-1})
查询当前集合所有索引:
db.userInfo.getIndexes()
查看总索引记录大小
db.userInfo.totalIndexSize()
读取当前集合所有index信息
db.userInfo.reIndex()
删除指定索引:
db.userInfo.dropIndex("name_1")
删除所有索引
db.userInfo.dropIndexes()



添加:
1
2
db.userInfo.save({'name':'zhangsan','age':25,sex:true})
添加的数据的数据列,没有固定,根据添加的数据为准



修改:
1
2
3
4
5
db.userInfo.update({age:25},{$set:{name:'lisi'}},false,true)
相当于:update users set name = ‘changeName’ where age = 25;
db.userInfo.update({name:'lisi'},{$inc:{age:50}},false,true)
相当于:update users set age = age + 50 where name = ‘lisi’;
db.userInfo.update({'name':'lisi'},{$inc:{'age':50},$set:{name:'hoho'}},false,true)



删除:
1
db.userInfo.remove({'age': 132})



查询修改删除:
1
2
3
4
5
6
7
8
9
10
11
12
db.userInfo.findAndModify({
    query:{age:{$gte:25}},
    sort:{age:-1},
    update:{$set:{name:'a2'},
    $inc:{age:2}},
    remove:true})
db.runCommand({findandmodify:'usersInfo',
    query: {age:{$gte:25}},
    sort: {age:-1},
    update:{$set:{name:'a2'},$inc:{age:2}},
    remove:true})
update 或 remove 其中一个是必须的参数; 其他参数可选。



排序:
1
2
升序:db.userInfo.find().sort({age:1})
降序:db.userInfo.find().sort({age:-1})



将一个对象转换成json
1
2
tojson(new Object())
tojson(new Ojbect('a'))



循环添加数据:
1
2
3
4
5
> for (var i = 0; i < 30; i++) {
    db.userInfo.save({name:'u_' + i, age:22 + i,sex:i % 2})
    }
这样就循环添加了30条数据,同样也可以省略括号的写法
> for (var i = 0; i < 30; i++) {db.userInfo.save({name:'u_'+i,age:22+i,sex:i%2})}



find 游标查询
1
2
3
4
5
6
7
8
> var cursor = db.userInfo.find()
> while (cursor.hasNext()) {
    printjson(cursor.next())
    }

这样就查询所有的users信息,同样可以这样写
var cursor = db.users.find();
while (cursor.hasNext()) {printjson(cursor.next)}



forEach迭代循环
1
2
db.users.find().forEach(printjson)
forEach中必须传递一个函数来处理每条迭代的数据信息



将find游标当数组处理
1
2
3
4
5
6
7
8
9
10
11
var cursor = db.users.find()
cursor[4]
取得下标索引为4的那条数据
既然可以当做数组处理,那么就可以获得它的长度:cursor.length();或者cursor.count();
那样我们也可以用循环显示数据
for (var i = 0 ,len = c.length(); i < len; i++) printjson(c)

将find游标转换成数组
>var arr = db.userInfo.find().toArray()
>printjson(arr[2])
用toArray方法将其转换为数组



其他:

1
2
查询之前的错误信息:db.getPrevError();
清除错误记录:db.resetError()



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-66422-1-1.html 上篇帖子: MongoDB 自动启动脚本 下篇帖子: Mongodb安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表