MongoDB是一个基于分布式文件存储的数据库。由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系型数据库和非关系型数据库之间的产品,是非关系型数据库当中功能最丰富,最像关系型数据库的。
MongoDB是非关系型数据库当中最像关系型数据库的,所以我们通过它与关系型数据库的对比,来了解下它的概念。
SQL概念 | MongoDB概念 | 解释/说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
本文使用MongoDB版本为4.2.5,MongoDB客户端工具为Robo 3T
> use test
switched to db test
> db.article.insert({name:"MongoDB 教程"})
WriteResult({ "nInserted" : 1 })
> show dbs
admin 0.000GB
config 0.000GB
local 0.000GB
test 0.000GB
> db.dropDatabase()
{ "dropped" : "test", "ok" : 1 }
> show dbs
admin 0.000GB
config 0.000GB
local 0.000GB
> use test
switched to db test
> db.createCollection("article")
{ "ok" : 1 }
> show collections
article
> db.article.drop()
true
> show collections
上面的数据库和集合操作是在MongoDB的客户端中进行的,下面的文档操作都是在Robo 3T中进行的。
db.collection.insert(document)
db.article.insert({title: ‘MongoDB Test‘,
description: ‘MongoDB is a Nosql database‘,
by: ‘zhangsan‘,
url: ‘https://www.mongodb.com/‘,
tags: [‘mongodb‘, ‘database‘, ‘NoSQL‘],
likes: 100
})
db.article.find({})
{
"_id" : ObjectId("6b7714661379a101445e3927"),
"title" : "MongoDB Test",
"description" : "MongoDB is a Nosql database",
"by" : "zhangsan",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100.0
}
db.collection.update(
<query>,
<update>,
{
multi: <boolean>
}
)
# query:修改的查询条件,类似于SQL中的WHERE部分
# update:更新属性的操作符,类似与SQL中的SET部分
# multi:设置为true时会更新所有符合条件的文档,默认为false只更新找到的第一条
db.article.update({‘title‘:‘MongoDB 教程‘},{$set:{‘title‘:‘MongoDB‘}},{multi:true})
db.collection.save(document)
db.article.save({
"_id" : ObjectId("6b7714661379a101445e3927"),
"title" : "MongoDB Test",
"description" : "MongoDB is a Nosql database",
"by" : "zhangsan",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100.0
})
remove()
方法来删除集合中的文档,语法如下;db.collection.remove(
<query>,
{
justOne: <boolean>
}
)
# query:删除的查询条件,类似于SQL中的WHERE部分
# justOne:设置为true只删除一条记录,默认为false删除所有记录
db.article.remove({‘title‘:‘MongoDB Test‘})
db.collection.find(query, projection)
# query:查询条件,类似于SQL中的WHERE部分
# projection:可选,使用投影操作符指定返回的键
db.article.find()
/* 1 */
{
"_id" : ObjectId("6b7714661379a101445e3927"),
"title" : "MongoDB Test",
"description" : "MongoDB is a Nosql database",
"by" : "zhangsan",
"url" : "https://www.mongodb.com/",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 50.0
}
操作 | 格式 | SQL中的类似语句 |
---|---|---|
等于 | { |
where title = ‘MongoDB Test‘ |
小于 | { |
where likes < 50 |
小于或等于 | { |
where likes <= 50 |
大于 | { |
where likes > 50 |
大于或等于 | { |
where likes >= 50 |
不等于 | { |
where likes != 50 |
db.article.find({‘title‘:‘MongoDB 教程‘})
db.article.find({‘likes‘:{$gt:50}})
db.article.find({‘title‘:‘MongoDB Test‘,‘by‘:‘zhangsan‘})
db.article.find({$or:[{"title":"MongoDB"},{"title": "MongoDB Test"}]})
db.article.find({"likes": {$gt:50}, $or: [{"title": "MongoDB"},{"title": "MongoDB Test"}]})
db.collection.find().limit(NUMBER)
db.article.find().limit(3)
db.collection.find().limit(NUMBER).skip(NUMBER)
db.article.find().limit(2).skip(1)
db.collection.find().sort({KEY:1})
db.article.find().sort({likes:-1})
索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。
MongoDB使用createIndex()方法来创建索引,语法如下;
db.collection.createIndex(keys, options)
# background:建索引过程会阻塞其它数据库操作,设置为true表示后台创建,默认为false
# unique:设置为true表示创建唯一索引
# name:指定索引名称,如果没有指定会自动生成
db.article.createIndex({"title":1,"description":-1}, {background: true})
db.article.getIndexes()
/* 1 */
[
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "test.article"
},
{
"v" : 2,
"key" : {
"title" : 1.0,
"description" : -1.0
},
"name" : "title_1_description_-1",
"ns" : "test.article",
"background" : true
}
]
db.collection.aggregate(AGGREGATE_OPERATION)
聚合中常用操作符如下;
| 操作符 | 描述 |
| ---- | ----- |
| $sum | 计算总和 |
| $avg | 计算平均值 |
| $min | 计算最小值 |
| $max | 计算最大值 |
根据by字段聚合文档并计算文档数量,类似与SQL中的count()函数;
db.article.aggregate([{$group : {_id : "$by", sum_count : {$sum : 1}}}])
/* 1 */
{
"_id" : "zhangsan",
"sum_count" : 2.0
}
/* 2 */
{
"_id" : "lisi",
"sum_count" : 1.0
}
db.article.aggregate([{$group : {_id : "$by", avg_likes : {$avg : "$likes"}}}])
/* 1 */
{
"_id" : "zhangsan",
"avg_likes" : 100.0
}
/* 2 */
{
"_id" : "lisi",
"avg_likes" : 100.0
}
db.article.find({title:{$regex:"Test"}})
db.article.find({title:{$regex:"ZhangSan",$options:"$i"}})
原文:https://www.cnblogs.com/jason47/p/14422501.html