非关系型数据库MongoDB简介及增删改查常用命令

一、 什么是 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
在这里插入图片描述
欢迎大家阅读,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感谢。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值