一、相关概念
mongodb 是非关系型数据库中最像关系型数据库的。通过它与非关系型数据库对比来了解概念
SQL概念 | MongoDB概念 | 解释说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
二、数据库操作
创建数据库,使用 use 命令 去创建数据库当插入第一条数据时会创建数据库。eg:
use test
db.article.insert({name:"MongoDB 教程"})
show dbs
删除数据库,使用db对象中的dropDatabase()方法来删除;。eg:
db.dropDatabase()
show dbs
三、集合操作
创建集合,使用db对象中的createColletion()方法来创建集合,例如创建一个article 集合
use test
db.createCollection("article")
show collections
四、文档操作
插入文档
MongoDB 通过collection对象的insert()方法来插入文档,例如插入一个article文档
db.article.insert({
title: 'MongoDB 教程',
description: 'MongoDB 是一个 Nosql 数据库',
by: 'Andy',
url: 'https://www.mongodb.com/',
tags: ['mongodb', 'database', 'NoSQL'],
likes: 100
})
使用collection对象的find()方法可以获取文档例如获取所有的article文档;
db.article.find({})
更新文档
mongodb 通过collection对象的update()方法来更新集合中的文档,语法如下:
db.collection.update(
<query>,
<update>,
{
multi: <boolean>
}
)
# query:修改的查询条件,类似于SQL中的WHERE部分
# update:更新属性的操作符,类似与SQL中的SET部分
# multi:设置为true时会更新所有符合条件的文档,默认为false只更新找到的第一条
将title为MongoDB 教程的所有文档的title修改为MongoDB;
db.article.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})
除了update()方法以外,save()方法可以用来替换已有文档,语法如下;
db.collection.save(document)
这次我们将ObjectId为61357eb7af528c5d982d23b6的文档的title改为MongoDB 教程;
db.article.save({
"_id" : ObjectId("61357eb7af528c5d982d23b6"),
"title" : "MongoDB 教程",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Andy",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100.0
})
删除文档
MongoDB通过collection对象的remove()方法来删除集合中的文档,语法如下;
db.collection.remove(
<query>,
{
justOne: <boolean>
}
)
# query:删除的查询条件,类似于SQL中的WHERE部分
# justOne:设置为true只删除一条记录,默认为false删除所有记录
删除title为MongoDB 教程的所有文档;
db.article.remove({'title':'MongoDB 教程'})
查询文档
MongoDB通过collection对象的find()方法来查询文档,语法如下;
db.collection.find(query, projection)
# query:查询条件,类似于SQL中的WHERE部分
# projection:可选,使用投影操作符指定返回的键
查询article集合中的所有文档;
db.article.find()
MongoDB中的条件操作符,通过与SQL语句的对比来了解下;
操作 | 格式 | SQL中类似的语句 |
---|---|---|
等于 | {:} | where title = 'MongoDB 教程' |
小于 | {:{$lt:}} | where likes < 50 |
小于或等于 | {:{$lte:}} | where likes <= 50 |
大于 | {:{$gt:}} | where likes > 50 |
大于或等于 | {:{$gte:}} | where likes >= 50 |
不等于 | {:{$ne:}} | where likes != 50 |
条件查询,查询title为MongoDB 教程的所有文档;
db.article.find({'title':'MongoDB 教程'})
条件查询,查询likes大于50的所有文档;
db.article.find({'likes':{$gt:50}})
AND条件可以通过在find()方法传入多个键,以逗号隔开来实现,例如查询title为MongoDB 教程并且by为Andy的所有文档;
db.article.find({'title':'MongoDB 教程','by':'Andy'})
OR条件可以通过使用$or操作符实现,例如查询title为Redis 教程或MongoDB 教程的所有文档;
db.article.find({$or:[{"title":"Redis 教程"},{"title": "MongoDB 教程"}]})
AND 和 OR条件的联合使用,例如查询likes大于50,并且title为Redis 教程或者”MongoDB 教程的所有文档。
db.article.find({"likes": {$gt:50}, $or: [{"title": "Redis 教程"},{"title": "MongoDB 教程"}]})
五、其他操作
Limit与Skip操作
读取指定数量的文档,可以使用limit()方法,语法如下;
db.collection.find().limit(NUMBER)
只查询article集合中的2条数据;
db.article.find().limit(2)
跳过指定数量的文档来读取,可以使用skip()方法,语法如下;
db.collection.find().limit(NUMBER).skip(NUMBER)
从第二条开始,查询article集合中的2条数据;
db.article.find().limit(2).skip(1)
排序
在MongoDB中使用sort()方法对数据进行排序,sort()方法通过参数来指定排序的字段,并使用1和-1来指定排序方式,1为升序,-1为降序;
db.collection.find().sort({KEY:1})
按article集合中文档的likes字段降序排列;
db.article.find().sort({likes:-1})
索引
索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。
MongoDB使用createIndex()方法来创建索引,语法如下;
db.collection.createIndex(keys, options)
# background:建索引过程会阻塞其它数据库操作,设置为true表示后台创建,默认为false
# unique:设置为true表示创建唯一索引
# name:指定索引名称,如果没有指定会自动生成
给title和description字段创建索引,1表示升序索引,-1表示降序索引,指定以后台方式创建;
db.article.createIndex({"title":1,"description":-1}, {background: true})
查看article集合中已经创建的索引;
db.article.getIndexes()
聚合
MongoDB中的聚合使用aggregate()方法,类似于SQL中的group by语句,语法如下;
聚合中常用操作符如下;
操作符 | 描述 |
---|---|
$sum | 计算总和 |
$avg | 计算平均值 |
$min | 计算最小值 |
$max | 计算最大值 |
根据by字段聚合文档并计算文档数量,类似与SQL中的count()函数;
db.article.aggregate([{$group : {_id : "$by", sum_count : {$sum : 1}}}])
根据by字段聚合文档并计算likes字段的平局值,类似与SQL中的avg()语句;
db.article.aggregate([{$group : {_id : "$by", avg_likes : {$avg : "$likes"}}}])
正则表达式
MongoDB使用$regex操作符来设置匹配字符串的正则表达式,可以用来模糊查询,类似于SQL中的like操作;
例如查询title中包含教程的文档;
db.article.find({title:{$regex:"教程"}})
不区分大小写的模糊查询,使用$options操作符;
db.article.find({title:{$regex:"elasticsearch",$options:"$i"}})