MongoDB大部分的增删改查操作都是通过 db 这个对象进行的,比如创建新的集合,db.createCollection(‘student’) 或者查询 db.student.find()
是不是有点眼熟?是不是很像uniDB,因为uniDB本质上就是对MongoDB的一种封装。

以下的使用教学,全部以School作为数据库为例。

1、切换或创建数据库

  1. use School #切换到School数据库。MongoDB 无需预创建School数据库,在使用时会自动创建

MongoDB中没有创建数据库的语句,如果School原本不存在,则会自动创建。

2、创建Collection(集合)

这里的集合相当于mysql中的表,也就是 JSON 数据最外层的那一对大括号 { }

  1. db.createCollection('student') #创建一个聚集集合。MongoDB 其实在插入数据的时候,也会自动创建对应的集合,无需预定义集合

MongoDB 其实在插入数据的时候,也会自动创建对应的集合无需预定义集合,这一点和redis类似。

3、删除集合

  1. db.student.drop()

4、查找数据

格式:db.集合名.find(查询条件) 例:db.student.find({sname: ‘lisi’})
db.youCollection.find(criteria, filterDisplay)
criteria :查询条件,可选
filterDisplay:筛选显示部分数据,如显示指定列数据,可选(当选择时,第一个参数不可省略,若查询条件为空,可用{}做占位符,如下例第三句)

  1. db.student.find() #查询所有记录。相当于:select * from student
  2. db.student.find({sname: 'lisi'}) #查询sname='lisi'的记录。相当于: select * from student where sname='lisi'
  3. 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字段了
  4. db.student.find({sname: 'zhangsan', sage: 22}) #and 与条件查询。相当于:select * from student where sname = 'zhangsan' and sage = 22
  5. db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25
  6. db.youCollection.find(criteria, filterDisplay).pretty() #表示格式化输出

格式化输出:
image.png

5、插入数据

与数据库创建类似,插入数据时也会自动创建集合。
插入数据有两种方式:insert和save。

  1. db.student.insert({_id:1, sname: 'zhangsan', sage: 20}) #_id可选
  2. db.student.save({_id:1, sname: 'zhangsan', sage: 22}) #_id可选

这两种方式,其插入的数据中_id字段均可不写,会自动生成一个唯一的_id来标识本条数据。而insert和save不同之处在于:在手动插入_id字段时,如果_id已经存在,insert不做操作,save做更新操作;如果不加_id字段,两者作用相同都是插入数据。image.png
添加的数据其结构是松散的,只要是bson格式均可,列属性均不固定,根据添加的数据为准。先定义数据再插入,就可以一次性插入多条数据,截图如下
image.png
运行完以上例子,student 已自动创建,这也说明 MongoDB 不需要预先定义 collection ,在第一次插入数据后,collection 会自动的创建。截图如下:
image.png

6、修改数据

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可选参数

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

7、删除数据

  1. db.student.remove({sname: 'chenliu'}) #相当于:delete from student where sname='chenliu'

用JSON解释一下

以上感觉就是这样的

  1. const db = {
  2. "student": [
  3. {
  4. "name": "lisi",
  5. "score": {
  6. "English": 55,
  7. "Math": 100,
  8. "Computer": 88
  9. }
  10. },
  11. {
  12. "name": "zhangsan",
  13. "score": {
  14. "English": 69,
  15. "Math": 86,
  16. "Computer": 77
  17. }
  18. }
  19. ]
  20. }

JSON的是这样的;

  1. {
  2. "db": {
  3. "student": [
  4. {
  5. "name": "lisi",
  6. "score": {
  7. "English": 55,
  8. "Math": 100,
  9. "Computer": 88
  10. }
  11. },
  12. {
  13. "name": "zhangsan",
  14. "score": {
  15. "English": 69,
  16. "Math": 86,
  17. "Computer": 77
  18. }
  19. }
  20. ]
  21. }
  22. }