天天看点

Ubuntu 下mongodb的shell常用命令

输入​

​mongo​

​命令,进入shell交互界面

mongo      
show dbs  # 显示数据库列表
show collections #显示所有的集合 
show users #显示所有的用户名
use 数据库的名称  #切换数据库       

创建数据库

mongodb中没有创建数据库的命令。如果你想创建一个“School”的数据库,先运行​

​use School​

​​命令,之后做一些操作(如:创建聚集集合​

​db.createCollection('teacher')​

​,这样就可以创建一个名叫“School”的数据库。

执行完毕后,再 ​

​show dbs​

​ 此时School 数据库就创建成功了。

插入数据

两种方式: insert 和 save

db.student.insert({_id:10001,name:'tangxingkai',age:25})

db.student.save({name:'sunxiaohui',age:23})

 db.student.find()      

查找数据

db.youCollection.find(criteria, filterDisplay)


db.student.find()  #查询所有记录。相当于:select * from student

db.student.find({sname: 'lisi'})  #查询sname='lisi'的记录。相当于: select * from student where sname='lisi'

db.student.find({},{sname:1, sage:1}) #查询指定列sname、sage数据。相当于:select sname,sage from student。sname:1表示返回sname列,默认_id字段也是返回的,可以添加_id:0(意为不返回_id)写成{sname: 1, sage: 1,_id:0},就不会返回默认的_id字段了

db.student.find({sname: 'zhangsan', sage: 22}) #and 与条件查询。相当于:select * from student where sname = 'zhangsan' and sage = 22

db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25      

修改数据

db.youCollection.update(criteria, objNew, upsert, multi ) 

criteria: update的查询条件,类似sql update查询内where后面的 
objNew : update的对象和一些更新的操作符(如$set)等,也可以理解为sql update查询内set后面的。 
upsert : 如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。 
multi: mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。默认false,只修改匹配到的第一条数据。 
其中criteria和objNew是必选参数,upsert和multi可选参数 

db.student.update({sname: 'lisi'}, {$set: {sage: 30}}, false, true) #相当于:update student set sage =30 where sname = 'lisi';      

删除数据