MongoDB作为灵活丰富的数据库而深受人们的喜爱和欢迎。本文旨在讲解MongoDB,内容包括MongoDB的概念、支持的数据类型列表、与mysql对比、基础操作、增删改查、修改器等等。希望本教程可以带大家全面了解MongoDB数据库。
1、MongoDB的概念。
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
2、MongoDB支持的数据类型列表
String : 这是最常用的数据类型来存储数据。在MongoDB中的字符串必须是有效的UTF-8。
Integer : 这种类型是用来存储一个数值。整数可以是32位或64位,这取决于您的服务器。
Boolean : 此类型用于存储一个布尔值 (true/ false) 。
Double : 这种类型是用来存储浮点值。
Min/ Max keys : 这种类型被用来对BSON元素的最低和最高值比较。
Arrays : 使用此类型的数组或列表或多个值存储到一个键。
Timestamp : 时间戳。这可以方便记录时的文件已被修改或添加。
Object : 此数据类型用于嵌入式的文件。
Null : 这种类型是用来存储一个Null值。
Symbol : 此数据类型用于字符串相同,但它通常是保留给特定符号类型的语言使用。
Date : 此数据类型用于存储当前日期或时间的UNIX时间格式。可以指定自己的日期和时间,日期和年,月,日到创建对象。
Object ID : 此数据类型用于存储文档的ID。
Binary data : 此数据类型用于存储二进制数据。
Code : 此数据类型用于存储到文档中的JavaScript代码。
Regular expression : 此数据类型用于存储正则表达式
3、MongoDB 与mysql对比
mysql mongodb
db db
tables collections集合
row(行) document文档
colum(列) field
4、MongoDB数据库数据表的基础操作
本着存在就使用,不存在即创建的原则
use db 使用数据库,
db.dropDatabase() 删除数据库
show dbs 查看当前多有的数据库
show tables 查看数据表(collections)
show collections 一样的查看当前数据表
db.(数据表名).drop() 删除表
db 查看当前使用的是哪一个数据库
5、MongoDB文档的增删改查
以下info代表表(collections)
1>增
db.info.insert({'name':'huahua'}) (官方不推荐,既可以插入多条也可以只插入一条数据)
db.info.insertOne({'name':'huahua'})
db.info.insertMany([{'name':'huahua'}])
2>删
db.info.remove({条件})
db.info.deleteOne({条件})
db.info.deleteMany({条件})
3>改
db.info.update({条件},{$set:{name:18}})(同样官方推荐使用下面两种)
db.info.updateOne({条件},{$set:{name:18}})
db.info.updateMany({条件},{$set:{name:18}})
4>查
db.info.findOne({条件]})
db.info.find({条件})
db.info.find().pretty()格式化显示结果
6、常用条件
$lt #某个字段小于某个值 db.info.find({'age':{'$lt',20}}) ---->查询年龄小于20的所有结果
$gt #大于,$gte #等于,$lte#等于,$eq #等于,$ne #不等于,用法与上面一样
$in ##查询值在某一个范围内 db.info.find({'age';{'$in':[20,30]}}),查询年龄在20到30这个范围内的结果
$nin ##不在某一个范围内
$regex #正则匹配 db.info.find({'name';{'$regex':'^二*'}}) 查询名字以二开头的所有名字
$exists #判断某个字段是否存在 db.info.find({'name';{'$exists',True}})
$type #类型判断 db.info.find({"title" : {$type : 2}},#判断title是否为字符串
详细类型对应查考如下连接
https://www.runoob.com/mongodb/mongodb-operators-type.html
$text #文本查询 db.info.find('$text':{'search':'huahua'}),查询文本类型字段中包含哈哈的文档
$高级条件查询 db.info.find({'$where':'obj.age>18'}),查询年龄大于18的文档
({条件,条件} 表示两个或多个条件同时成立
({'$or':[{条件},{条件}]})表示至少一个成立
{'hoppy':{'$all:[0,1,2,3]}}当hoppy的值为[0,1,2,3]的子集时,查询成功
7、一些修改器
$修改器
$set 设置或者添加值
$unset 删除某一个字段
db.info.update{{条件},'$unset':{'age':1}}
$inc 引用增加
db.info.update{{条件},'$inc':{'age':1}}
array操作
$push 在array中追加一个新的元素
db.info.updateOne({条件,{'$push':{array:10}}})
$pull 在array中删除一个元素
db.info.updateOne({},{'$pull':{arry:10}})
$pop 在array中,如果为-1 则从前往后删,如果为1则从后往前删
db.info.updateOne({},{'$pop':{arry:1}})
db.info.updateOne({},{'$pop':{arry:-1})
修改里面array内值为5的值
db.db.info.updateOne({array:5},{'$set':{'arry.$':1}})#必须给定索引位置,$为查找到的那一个元素
object操作
db.info.updateOne({name:'huahua'},{'$inc':{'map.weight':-1}})
8、其他操作
count()计算表内数据总数---db.info.count()
limit() 查询几条数据---db.info.limit(5)
skip() 跳过几条数据---db.info.skip(5)
sort ()排序 ----db.info..sort({'age':1}) -- (按照年龄从小到大排序(1:代表升序)(-1:代表降序))
limit+sort+skip
db.info.limit(5).skip(5).sort()
优先级最高的是sort
其次为 skip
最低是 limit
9、创建索引,加快查询速度
(1)为什么要创建索引
索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常致命的。索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构
(2)创建索引
db.collection.createIndex(keys, options) ##语法中 Key 值为你要创建的索引字段,1 为指定按升序创建索引,如果你想按降序来创建索引指定为 -1 即可
db.info.createIndex({"title":1})
以上就是MongoDB基本操作的讲解。相信大家看完教程对MongoDB有了一个大致的了解,还想学习更多数据库的知识,可以上博学谷在线学习。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
程序员30岁后能干什么?还有发展前途吗?
关于程序员这个职业的发展常常会有人唱衰,在一些人的固有观念里,程序员就是青春饭,过了30岁就是在走职业的下坡路。其实这完全是一种偏见,技术岗位的生命周期是很长的,如果一个程序员只能干到35岁,只能证明工作的时候都是在混日子,没有用脑力而使用的蛮力。那么程序员30岁后能干什么?还有发展前途吗?其实无论是深入钻研技术,还是向管理层发展,其职业前景都是十分不错的。
2091
2020-01-12 11:58:04
一名优秀的程序员需要具备的六大素质
随着IT行业的发展,程序员这一岗位受到了众多人的青睐和追捧。然而许多不是科班出身朋友在考虑学习IT技术并转行前,都会思考这样一个问题:自己到底适不适合做程序员呢?其实这个问题的答案很简单,人人都可以学习IT编程,但是要成为一名优秀的程序员需要具备以下六大素质。
1191
2020-02-14 18:06:55
Android基础知识点面试复习整理
相信很多小伙伴在准备面试复习的时候,都会因为没有建立自己系统的知识结构,而常常翻开书本马冬梅,合上书本马什么梅。出现这样的情况并不是个例,因此大家应该努力建立自己的Android知识体系,这样多复习几遍,一些重难点就能了熟于胸了。本文为大家整理了一套全面的Android基础知识点,有面试复习需要的小伙伴赶紧收藏起来吧~
1348
2020-04-29 11:48:25
少儿编程有必要学吗?
随着社会的不断进步,人们的消费水平和生活水平都不断提高,越来越多的家长愿意花费更多的金钱和精力投入到对孩子的培养中。而在各种少儿培训中,除了舞蹈、美术、音乐等传统兴趣培训意之外,“少儿编程”也被人们更多关注。儿童编程在把计算机编程融合孩子兴趣的同时,加强孩子思维能力的锻炼,学习编程语言,可以锻炼孩子的逻辑思维
1158
2020-05-22 14:42:07
零基础转行IT学什么好?
IT岗位普遍高于传统行业的薪资水平,吸引了不少零基础的转行者。然而许多转业者一开始都难免面临这样的问题:零基础转行IT学什么好?IT技术岗位一般大致分为开发、测试和运维。随着软件产业的发展,这三种岗位都变得同样重要,技能要求也越来越广泛。比如测试岗位如今也要求具备一定的编程能力。因此,不管你选择什么岗位,只要技术过硬,都有着极大的发展前景。下面我们就来逐一分析适合零基础学习的IT技术。
772
2020-07-24 16:33:40
N+12传智播客2018秋季课程发布会
免费 基础 747
推荐课程
热门文章
- UI设计培训费用要多少钱?靠不靠谱?
- 哪个Python培训机构好些?怎么选?
- 这样的Java自学姿势 学废最快
- 2021年大数据行业发展前景及岗位方向如何?
- Web前端开发工程师培训班哪家好?
- 互联网产品经理岗位现在有多热门?
- 前端测试用例怎么写?为什么写测试用例?
- 有哪些好的线上培训产品经理的机构?
- 零经验的人学编程难吗?能学会吗?
- 传智博学谷神经网络和深度学习课程推荐 查看更多
扫描二维码,了解更多信息
