进行CRUD操作之前有必要了解mongoDB的数据模型。
MongoDB增删改查
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 相较于关系型数据库它最大的优点就是灵活、快速、高效。
MongoDB基本操作
创建数据库
use yourDB //使用一个数据库,如果不存在自动创建。MongoDB很多操作都会在目标不存在的时候创建一个新的可用目标
删除数据库
use yourDBdb.dropDatabase()
创建集合
db.createCollection(“yourCollection”)
创建集合有第二个可选参数 ,给集合增加条件,详情http://www.runoob.com/mongodb/mongodb-create-collection.html
删除集合
db.yourCollection.drop()
MongoDB 对文档进行CURD
插入
MongoDB 使用 insert() 或 save() 方法向集合中插入文档,语法如下:
1.db.COLLECTION_NAME.insert(document)
2.db.COLLECTION_NAME.insertOne(document)
3.COLLECTION_NAME.insertMany(【document1,document2,…】,{option}) //多文档插入时,集合必须存在
实例
以下文档可以存储在 MongoDB 的 game 数据库 的 Player 集合中:
db.Player.insert(
{
job: '法师',
name: '阿三',
health: 100,
defence: 50,
skills: ['skill1', 'skill2', 'skill3']
}
)
更新
Save()方法
save() 方法通过传入的文档来替换已有文档。所以既能做插入也能做更新。
update() 方法
update() 方法用于更新已存在的文档。语法格式如下:
db.collection.update( <query>, <update>, { upsert: <boolean>, multi: <boolean>, writeConcern: <document> })
参数说明:
query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如inc…)等,也可以理解为sql update查询内set后面的
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。
利用上述Player文档做如下更新操作:
db.Player.update({‘job’:’法师’},{$set:{‘job’:’战士’}})
更新操作符包括:
字段更新操作: $ + set /unset/inc/min/max 依次表示:替换字段/删除字段/增加字段值/求字段最小值/求字段最大值
$ + setOnInsert 如果更新函数可选参数upsert为true,仅当完成插入才将值分配给字段
数组更新操作: $ + addToSet/pop/pull/push/slice 向不存在的数组加值/删除数组头或尾端数据/输出数组所有满足条件的值/将值插入数组
查询
MongoDB 查询数据的语法格式如下:
db.collection.find(query, projection)
query :可选,使用查询操作符指定查询条件
projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)
运算符:
比较查询运算符: $ + eq/gt/gte/in/lt/lte/ne/nin 分别表示 = / > / >= / [,] / < / <= / != / ![,]
逻辑查询运算符: $ + and/not/nor/or 字面义
元素查询运算符: $ + exists 字面义
等式查询运算符: $ +regex 通过正则表达式来查询
删除操作
db.collecion.deleteOne(document)
db.collection.deleteMany(document)
所有操作运算符文档:https://docs.mongodb.com/manual/reference/operator/
CRUD文档 :https://docs.mongodb.com/manual/crud/