目录
一、 什么是 MongoDB
MongoDB 是一个跨平台的,面向文档的数据库,是当前NoSQL 数据库产品中最热门的一种。它介于关系数据库和非关系数据库之间,是非关系数据库当中功能最丰富,最像关系数据库的产品。它支持的数据结构非常松散,是类似 JSON 的BSON格式,因此可以存储比较复杂的数据类型。
MongoDB 的官方网站地址是:http://www.mongodb.org/
二、MongoDB 特点
MongoDB最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。它是一个面向集合的,模式自由的文档型数据库。
具体特点总结如下:
(1)面向集合存储,易于存储对象类型的数据
(2)模式自由
(3)支持动态查询
(4)支持完全索引,包含内部对象B
(5)支持复制和故障恢复
(6)使用高效的二进制数据存储,包括大型对象(如视频等)
(7)自动处理碎片,以支持云计算层次的扩展性
(8)支持 Python,PHP,Ruby,Java,C,C#,Javascript,Perl 及C++语言的驱动程序,社区中也
提供了对 Erlang 及.NET 等平台的驱动程序
(9) 文件存储格式为 BSON(一种 JSON 的扩展)
三、MongoDB 体系结构
MongoDB 的逻辑结构是一种层次结构。
主要由:文档(document)、集合(collection)、数据库(database)这三部分组成的。逻辑结构是面向用户的,用户使用 MongoDB 开发应用程序使用的就是逻辑结构。
(1)MongoDB 的文档(document),相当于关系数据库中的一行记录。
(2)多个文档组成一个集合(collection),相当于关系数据库的表。
(3)多个集合(collection),逻辑上组织在一起,就是数据库(database)。
(4)一个 MongoDB 实例支持多个数据库(database)。文档(document)、集合(collection)、数据库(database)的层次结构如下图:
下表是 MongoDB 与 MySQL 数据库逻辑结构概念的对比:
四、 数据类型
基本数据类型
null:用于表示空值或者不存在的字段,{“x”:null}
布尔型:布尔类型有两个值 true 和 false,{“x”:true}
数值:shell 默认使用 64为浮点型数值。{“x”:3.14}或{“x”:3}。对于整型值,可以使用NumberInt(4字节符号整数)或 NumberLong(8 字节符号整数),{“x”:NumberInt(“3”)}{“x”:NumberLong(“3”)}
字符串:UTF-8 字符串都可以表示为字符串类型的数据,{“x”:“呵呵”}
日期:日期被存储为自新纪元依赖经过的毫秒数,不存储时区,{“x”:new Date()}
正则表达式:查询时,使用正则表达式作为限定条件,语法与 JavaScript的正则表达式相同,
{“x”😕[abc]/}
数组:数据列表或数据集可以表示为数组,{“x”: [“a“,“b”,”c”]}
内嵌文档:文档可以嵌套其他文档,被嵌套的文档作为值来处理,{“x”:{“y”:3 }}
对象 Id:对象 id 是一个 12 字节的字符串,是文档的唯一标识,{“x”:objectId() }
二进制数据:二进制数据是一个任意字节的字符串。它不能直接在 shell 中使用。如果要将非 utf-字符
保存到数据库中,二进制数据是唯一的方式。
代码:查询和文档中可以包括任何 JavaScript 代码,{“x”:function(){/…/}}
五、MongoDB实现增删改查基本命令
mongod:
打开或者新建一个数据库 :mongod --dbpath dir
mongoinport:
导入mongo文件 :mongoinport --db test --collection user --drop --file C:\User\mongodb\document.json
–db 导入到哪个库
–collection 导入到哪个集合
–drop 加上就表示清空原有文档
–file 要导入的文件
mongo:
创建一个新的库 :use dbname
查看所有库 :show dbs
查看当前库所有集合 :show collection
增加:
在名为collectionName的集合中插入一条文档,如果集合不存在,则新建该集合 :db.collectionName.insert(obj)
例子:在student集合中插入文档
db.student.insert({
id:101,
name: '张三',
sex: '男',
address: '广东'
})
查询:
查找名为collection集合的所有文档 :db.collectionName.find()
查询k的值为v的文档 : db.collectionName.find({k : v})
查询k1的值为v1 且 k2的值为v2的文档 :db.collectionName.find({k1 : v1},{k2 : v2})
查询k1的值为v1 或 k2的值为v2的文档 :db.collectionName.find($or : {k1 : v1},{k2 : v2})
查询k的值大于v的文档,$ gte大于等于(>=) : db.collectionName.find({k : {$gt:v}})
查询k的值小于v的文档,$ lte小于等于(<=) : db.collectionName.find({k : {$lt:v}})
查询前三条数据 :db.collectionName.find().limit(3)
修改:
修改文档
db.collectionName.update(
{k1 : v1}, //修改k1的值为v1的文档
{
$set:{k2 : v2, k3 : v3},
}
)
替换文档
db.collectionName.update{
{k1 : v1},
{
k2 : v2,
k3 : v3
}
}
删除:
删除当前所在的数据库 :db.dropDatabase()
删除集合 :db.collectionName.drop()
删除匹配到的所有k为v值的文档 :db.collectionName.remove({k : v})
删除第一个匹配到的所有k为v值的文档 :db.collectionName.remove({k : v},{justOne:true})
清空集合 :db.collectionName.remove({})
排序
db.collectionName.find().sort({k1 : 1},{k2 : -1})
按照k1来排序、如果k1的值相同、按照k2来排序、1代表升序、-1降序
统计条数
db.collectionName.count({k : v})
模糊查询
查询有XXX
db.collectionName.find({k : /模糊查询字符串/})
//比如查询名字包含"定"字的人:
db.collectionName.find({name:/定/})
查询以XXX开头
db.collectionName.find({k : /^字符串/})
//比如查询名字以"郑"开头的人:
db.collectionName.find({name:/^郑/})
查询以XXX字结尾
db.collectionName.find({k : /字符串$/})
//比如查询名字以"移"字结尾的人:
db.collectionName.find({name:/移$/})
包含
db.collectionName.find({k : {$in[v1,v2]}})
//比如查询userid字段包含3和4的文档:
db.collectionName.find({userid:{$in["3","4"]}})
不包含
db.collectionName.find({k : {$nin[v1,v2]}})
//查询userid字段不包含2和3的文档:
db.collectionName.find({userid:{$nin["2","3"]}})
六、Docker安装MongoDB
在宿主机创建 mongo 容器
docker run -id --name=ktc_mongo -p 27017:27017 mongo
远程登陆
mongo 192.168.12.128
MongoDB客户端操作起来未免太过复杂,因此我们采用第三方的可视化工具来帮我们操作MongoDB,就类似于我们使用Navicat来操作MySQL一样
七、MongoDB的可视化工具
1、NoSQLBooster for MongoDB
2、Robo 3T
欢迎大家阅读,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感谢。