Mongodb最基础入门教程
Mongodb最基础入门教程
如果想了解一下redis的入门教程,可以去看一下我的上一篇博客
Mongodb的安装大家可以参考一下其他博主的博客,这里我就不做介绍了。不过值得注意的是,在Linux版本中如果启动mongodb的时候出现下面这个错误(在windows版本中不会出现下面的问题):
mongod: /usr/lib/libcurl.so.4: version `CURL_OPENSSL_3' not found (required by mongod)
原因是因为mongodb启动需要的是libcurl.so.3。在我们安装好libcurl.so.3后,我们可以使用下面的命令打开,其中LD_PRELOAD后面跟随的是库的位置。(/data/db文件夹需要赋予可读写的权限)
LD_PRELOAD=/usr/lib/libcurl.so.3 mongod --dbpath /data/dblll
简介
Mongodb是一种非关系性数据库(nosql),关于nosql的介绍可以去看一看菜鸟教程
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
下面是Sql与mongodb的术语对比
| SQL | Mongodb |
|---|---|
| 表(Talbe) | 集合(Collection) |
| 行(Row) | 文档(Document) |
| 列(Col) | 字段(Field) |
| 主键(Primary Key) | 对象ID(ObjectId) |
| 索引(Index) | 索引(Index) |
| 嵌套表(Embeded Table) | 嵌入式文档(Embeded Document) |
| 数组(Array) | 数组(Array) |
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。在Mongodb中,对于插入的格式并没有要求,字段类型可以随意变动。例如,在我创建一个集合后,我们可以在这个集合加入下面的数据:
{
"name":"this is a name",
"age":12
}
同样我们也可以在这个数据库插入这样的数据。
{
"name":8888,
"address":"changsha"
}
当插入这两个数据后,使用Robo3T数据库可视化工具显示如下:
通过这个我们知道,在向mongodb的同一个表中插入数据的时候,插入的数据字段类型可以不一样,即使是相同的字段数据类型也可以不一样。
不过即使mongodb可以这样做,也能够这样做,但是却不是我们应该这样做的理由,我们在设计数据库的时候,应尽量提前考虑好数据库应有的字段,同时每一个字段应该使用同一种数据类型,这样我们才能紧紧的将程序o把握在我们的手里面。
插入数据
首先我们先创建一个名字为test_data_1的集合。
插入一条文档
db.getCollection('test_data_1').insertOne(
{
"name":8888,
"address":"changsha"
}
)
当然,将这一条语句写成一行也是没有问题的。其中,Key(也就是上面的name和address)是可以不带引号的,同时对于字符串也可以使用单引号,不过为了统一,在后面统一使用双引号。
下面是执行这一条数据返回的结果
{
"acknowledged" : true,
"insertedId" : ObjectId("5d5f9e5c0336f9e82b3f9d74")
}
其中acknowledged代表数据是否被承认。其中,每一条数据被插入的时候都会返回一个字段“_id”,也就是ObjectId,它是由时间、机器码、进程pid和自增计数器构成的。“_id”始终递增,并绝对不重复。
插入多个文档
mongodb也同时支持一次插入多个文档
db.getCollection('test_data_1').insertMany([
{
"name":"名字1",
},
{
"name":"名字2",
},
{
"address":"湖南"
},
]
)
这里我们又可以想一想,我们是否可以使用insertOne实现insertMany的功能?肯定是可以的,但是会造成什么影响呢?我们可以从网络带宽,磁盘IO,机器性能,以及稳定性来考虑。
在插入相同大小的数据时,使用insertMany的性能要明显好于insertOne,因为insertOne会频繁的调用去插入数据,而insertMany却只会调用一次。如果mangodb数据库与调用者不在同一台机器上,那么性能相差便会更大,因为数据在网络传输的过程中会添加其他的报文。那么插入数据的时候是不是应该将数据全部一次插入呢?也不是!!试想一下,如果插入的数据过多,将磁盘的IO占满了,那么必会对其他程序造成影响。并且,如果在快要插入完所有数据的时候,服务器断电了,那么……所以说,应该合理的选择一次性插入数据库的数量。
查询数据
查询所有数据
db.getCollection('test_data_1').find({})
其中{}里面包含的是查询条件,因为是查询所有的数据,所以直接为空就行了,或者省略{}也行。
查询特定的数据
db.getCollection('test_data_1').find({"字段1":"固定值1","字段2":"固定值2"})
查询范围值数据
下面是查询i范围值的语法,至于操作符,我们后面再说。
db.getCollection('test_data_1').find(
{
"字段1":{"操作符1":边界1,"操作符2":边界2},
"字段2":{"操作符1":边界1,"操作符2":边界2}
}
)
查询范围值的数据简单,举一个示例:
和前面查询特定的数据的方法一样,只不过固定值变成了范围({"$gt":10}代表大于10)。
下面是范围操作符及其意义:
| 操作符 | 意义 |
|---|---|
| $gt | 大于(great than) |
| $gte | 大于等于(great than equal) |
| $lt | 小于(less than) |
| $lte | 小于等于(less than equal) |
| $ne | 不等于(not equal) |
限定返回字段
在前面的几张图片中,我们可以看到,使用find操作的时候,返回了所有的字段,那么如果我们并不想要某一些字段的时候,我们应该怎么做呢?
db.getCollection('test_data_1').find(用于过滤的条件,用于限定的条件)
下面便是两个例子:
去除age

只返回age

大家会发现,在后面的用于限定的条件中,如果age为1,则返回了age和**_id**,如果age为0,则返回了**_id和name**。在不考虑_id的情况下,我们可以理解:
如果某一个字段被限定为0,则代表该字段不返回(也就是默认其它字段为1),所以其他未被限定的字段则一定会被返回
如果某一个字段被限定为1,则代表该字段返回(也就是默认其它字段为0),所以其他未被限定的字段则不会被返回
_id比较特殊,无论怎样,都要默认返回,当是如果我们真的不需要,那么必须就要把"_id"设置为0。
修饰返回结果
得到数据的条数
db.getCollection('test_data_1').find({}).count()限定返回结果数量
db.getCollection('test_data_1').find({}).limit(限制返回的数量)对结果进行排序
db.getCollection('test_data_1').find({}).sort({"字段名":-1或者1})其中-1为逆序,1为正序。
修改数据
修改数据的前一部分是需要找到数据,然后才能进行修改。同样,在mongodb中,有两种方法修改数据(实际上有很多种)
- updateOne:只更新第一条符合条件的数据
- updateMany:更新所有符合条件的数据
下面介绍updateMany的更新数据
db.getCollection('test_data_1').updateMany(
// 下面是查询条件
{
"字段名1":"查找条件1","字段名2":"查找条件2"
},
// 进行修改
{
"$set":{"字段名":"新的数据","字段名":"新的数据"}
}
)
其中,如果在进行在进行修改的步骤中,如果字段名以前不存在则会进行增添。
当然,更新数据的内容不可能就这么一点点,但是因为这仅仅是一个基础入门教程,其他的就拜拜吧!想了解更多可以去看看其他的教程。
删除数据
删除数据也有两种操作,deleteOne和deleteMany。和修改数据的情况差不多,一个是删除第一条满足条件的,一个是删除所有满足条件的。
还是以deleteMany来说:
db.getCollection('test_data_1').deleteMany(
// 删除的条件
{
"字段名1":"值","字段名2":"值2"
}
)
说完简单的mongodb的操作(增删改查)我们现在可以来说一说稍微复杂一点点的操作了。
数据去重
在mongodb中进行数据去重是一个很简单的操作。使用distinct即可。它可以接收两个参数,第一个参数为需要被去重的字段名,第二个参数是进行去重的条件(去重条件也就是进行查询操作的第一个参数,可以省略)。
db.getCollection('test_data_1').distinct(去重的字段名,去重的条件)
下面举个例子:
db.getCollection('test_data_1').distinct("name",{"age":{"$ne":10}})
这个的含义就是,在age不等于10的条件下对name字段进行去重!那么返回的数据是什么呢?是一个数组,里面是去重后的表中name字段的非重复的数据。
注意:这个去重是对返回值去重,而不是对数据库里面数据去重,也就是说,执行了这个操作,数据库没有发生任何改变。
在这一章只介绍了mongodb的最最基础的一些东西,本来是想介绍一下Mongodb的其他操作,但是发现其他的操作稍微要复杂一点,所以准备在下一章写。这一章的介绍就介绍到这里,下一篇博客我将介绍一下Mongodb的其他操作。
参考
参考书籍:《左手Mongodb,右手Redis》
Mongodb最基础入门教程的更多相关文章
- [置顶] IOS 基础入门教程
IOS 基础入门教程 教程列表: IOS 简介 IOS环境搭建 Objective C 基础知识 创建第一款iPhone应用程序 IOS操作(action)和输出口(Outlet) iOS - 委托( ...
- Python基础入门教程
Python基础入门教程 Python基础教程 Python 简介 Python环境搭建 Python 基础语法 Python 变量类型 Python 运算符 Python 条件语句 Python 循 ...
- React Native基础&入门教程:初步使用Flexbox布局
在上篇中,笔者分享了部分安装并调试React Native应用过程里的一点经验,如果还没有看过的同学请点击<React Native基础&入门教程:调试React Native应用的一小 ...
- Linux基础入门教程
Linux基础入门教程 --------- Linux学习路径 Linux学习者,常常不知道自己改怎么学习linux:Linux初级,也就是入门linux前提是需要有一些计算机硬件相关的知识或是有一下 ...
- 1.0 Android基础入门教程
1.0 Android基础入门教程 分类 Android 基础入门教程 本教程于2015年7月开始撰写,耗时半年,总共148节,涵盖了Android基础入门的大部分知识,由于当时能力局限,虽已竭尽全力 ...
- ECMAScript 6.0基础入门教程
ECMAScript 6.0基础入门教程 转:https://blog.csdn.net/hexinyu_1022/article/details/80778727 https://blog.csdn ...
- WordPress安装:零基础入门教程
WordPress安装:零基础入门教程 1主机空间要求要运行 WordPress,主机空间需满足以下条件.不过现在网络上的空间基本都可以,而且还让你随意定制Php和Mysql版本,至于空间和数据库大小 ...
- Vue-Router 基础入门教程
Vue-Router 基础入门教程 前言 这周的计划是用VUE将之前的小demo的前端给重构了,并且做成前后端分离的样式,因为之前的那个聊天室的demo几乎都是在一个路由上完成的,所以学习Vue-ro ...
- MongoDB学习——基础入门
MongoDB--基础入门 MongoDB是目前比较流行的一种非关系型数据库(NoSql),他的优势这里不废话,我们关注怎么使用它. 安装 下载,首先肯定要去下载,我们去官网下载,在国内,可能没FQ可 ...
随机推荐
- 精美的在线icon
super-tiny-icons(0.2.1)列表 序号 名称 图标 地址 是否使用 1 acast.svg https://cdn.jsdelivr.net/npm/super-tiny-icons ...
- Excel催化剂开源第8波-VSTO开发之异步调用方法
在VSTO开发过程中,因其和普通的Winform开发有点差别,具体细节笔者也说不清楚,大概是VSTO的插件是寄生在Excel中,不属于独立的进程之类的,其异步方法调用时,未能如Winform那样直接用 ...
- [git] 基础命令笔记
--内容整理自廖雪峰的GIT教程-- git status 查看当前工作区状态,显示未跟踪的文件以及未上传的修改记录 git init 使当前文件夹变成Git可以管理的仓库 git add xxx 将 ...
- LiteDB源码解析系列(3)索引原理详解
在这一章,我们将了解LiteDB里面几个基本数据结构包括索引结构和数据块结构,我也会试着说明前辈数据之巅在博客中遇到的问题,最后对比mysql进一步深入了解LiteDB的索引原理. 1.LiteDB的 ...
- 微信小程序踩坑日记1——调用微信授权窗口
0. 引言 微信小程序为了优化用户体验,取消了在进入小程序时立马出现授权窗口.需要用户主动点击按钮,触发授权窗口. 那么,在我实践过程中,出现了以下问题. . 无法弹出授权窗口 . 希望在用户已经授权 ...
- 在父页面用Iframe加载子页面时,将父页面的title替换成子页面title
报告管理
- SpringMVC表单对象绑定到@ModelAttribute
支持绑定表单对象 jsp: <%@ taglib prefix="form" uri="http://www.springframework.org/tags/fo ...
- [ PyQt入门教程 ] Qt Designer工具的使用
Qt Designer是PyQt程序UI界面的实现工具,Qt Designer工具使用简单,可以通过拖拽和点击完成复杂界面设计,并且设计完成的.ui程序可以转换成.py文件供python程序调用.本文 ...
- hdu多校第八场Parentheses Matrix
#include<bits/stdc++.h> using namespace std; ][]; int main() { int t; scanf("%d",&am ...
- Promise异步编程解决方案
Promise是ES6中新增的异步编程解决方案,体现在代码中它是一个对象,可以通过 Promise 构造函数来实例化. 其最基本的使用 new Promise(function(resolve,rej ...

