Mongodb基础用法【总结】

关系型数据库和非关系型数据库的区别

关系型数据库
1.在关系型数据库中,数据都是存储在表中的,对存储的内容有严格的要求
2.因为我们在创建表的时候久已经规定了表中的字段 存储的数据类型 是否为空 唯一标识等规则
3.由于操作的都是结构化的数据,所以我们需要使用结构化语言sql来操作
非关系型数据库
1.没有表概念 所以存储数据更加灵活 不规定字段 数据类型 是否为空 唯一标识等
2.由于数据没有严格要求,所以无需食用sql来操作

在mongodb中我们存储的数据是一个类似于json的格式叫BSON 例如 {name:wyf,age:18,sex:1}

高并发 高性能 高可用

拓展性强 不需要指定列

mongodb的缺点 对事务的支持不是很友好

mongodb中记录的就是一个文档 一个数据库中有多个集合 每个集合包含多个文档 域(就是字段) Mongodb通过嵌入式文档来代替多表联查

mongodb的基础常用命令

show dbs查询所有库 mongodb存储分为两部分 上面是内存 下面是磁盘 当我们用use 创建库的时候 我们的库现在在内存中 没有持久化到磁盘 当我们新建的库有一个文档数据的时候 就会自动存如磁盘中

mongodb默认的3个库
1.admin 就是用来存储用户信息的库
2.local这个库的数据永远不会被复制,可以用来存储先于本地单台服务器的任意集合
3.config 当mongodb用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。

创建数据库
use [数据库名称] 如果use没有这个数据库就会创建一个 如果有那就切换到这个数据库

文档类似于mysql的一行数据

集合类似于mysql的table

数据库的删除
db.dropDatabase()

创建集合(集合就相当于mysql中的表)
显示创建
db.createCollection(“集合名称”) 不管里面是否有文档 先把这个集合创建出来
隐式创建

插入文档的时候 集合如果不存在 则创建集合

删除集合
db.集合名称.drop() 返回true就代表删除成功

插入文档
单条
db.集合名称.insert({})
多条
db.集合名称.insertMany({})

如果没有这个集合名称 就会被隐式创建

如果某一条数据插入失败就比较麻烦 我们想要找到具体的报错可以使用 try catch机制

1.try 将可能抛出异常的代码放在try中
2.catch 如果try块中的代码抛出异常,catch块将捕获这个异常,并允许定义错误处理逻辑

查询所有
db.集合名称.find()

查询指定的数据
db.集合名称.find({“”:””})

查询第一条数据
db.集合名称.findOne({“”:””})

投影查询 (只想显示部分的字段)
db.集合名称.find({“id”:”1”},{“id”:”1”})
这样就只会显示我们的id字段

文档更新

覆盖修改
db.集合名称.update({_id:”1”},{“要修改的字段”:”修改内容”})
如何这种方法 会把之前的文档数据全部修改

局部修改
db.集合名称.update({_id:”2”},{$set:{“修改字段”:”修改内存”}})
这种方法更改指定字段并保留其他数据

批量修改
db.集合名称.update({_id:”2”},{$set:{“修改字段”:”修改内存”}},{multi:true})就是批量修改符合类型的文档

最新的mongodb中支持updateMany的函数可以直接修改批量数据

列值增长修改
db.集合名称.update({_id:””},{$inc:{要增长的字段:1}})
代表这个字段每次增长1 _id后面的值是字符串 例如 【增长字段开始为666】增长完就是667

删除文档
db.集合名称.remove({“要删除的文档字段”:”条件”})

全部删除
db.集合名称.remove({不加条件})

分页查询
1.统计数据
db.collection.count() //查询所有
db.collection.count({“”:””}) //查询指定条件数量
2.显示指定条数
db.comment.find().limit()
3.跳过某些数据进行查询
db.comment.find().limit().skip(从第几条跳过)
4.排序
db.comment.find().sort({“条件字段”:”1”}) 1代表升序 -1代表降序

比较复制的查询

通过正则的形式实现模糊查询
1.db.comment.find({“字段”:/条件/})
mongodb复制的正则也可也接收
大于某条件
2.db.集合名称.find({条件字段:{KaTeX parse error: Expected 'EOF', got '}' at position 18: …:NumberInt(700)}̲}) ![在这里插入图片描述]…in:[“1003”]})
里面是个数组 可以包含多个条件
条件查询
and或者or
db.集合名称.find({KaTeX parse error: Expected '}', got 'EOF' at end of input: and:[{字段:NumberInt(700)},{字段:{KaTeX parse error: Expected 'EOF', got '}' at position 19: …NumberInt(2000)}̲}]}) 点赞数大于700 小…or:[{字段:”条件”},{“字段”:”条件”}])
在这里插入图片描述
索引-Index
mongodb的索引使用的是B-Tree
单字段索引
在某一字段查询添加索引, 假如添加的字段值为30 那么先查询到索引的30 在通过30找到该集合
复合索引
列出的字段顺序具有重要意义,例如符合索引由(userid:1,score:-1)组成,则索引首先按userid正序排序,然后在内个userid的值内,再在按score倒序排序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/897352.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一款.NET开源的i茅台自动预约小助手

前言 今天大姚给大家分享一款.NET开源、基于WPF实现的i茅台APP接口自动化每日自动预约(抢茅台)小助手:HyggeImaotai。 项目介绍 该项目通过接口自动化模拟i茅台APP实现每日自动预约茅台酒的功能,软件会在指定时间开始对管理的用…

【UE5】将2D切片图渲染为体积纹理,最终实现使用RT实时绘制体积纹理【第六篇-阶段总结篇】

因为马上就要进入下一个阶段,制作动态编辑体积纹理的模块。 但在这之前,要在这一章做最后一些整理。 首先,我们完成没完成的部分。其次,最后整理一下图表。最后,本文附上正在用的贴图 完善Shader 还记得我们之前注…

HBuilder X 中Vue.js基础使用1(三)

一、 模板语法 Vue 使用一种基于 HTML 的模板语法,使我们能够声明式地将其组件实例的数据绑定到呈现的 DOM 上。所有的 Vue 模板都是语法层面合法的 HTML,可以被符合规范的浏览器和 HTML 解析器解析。 英文官网: Vue.js - The Progressive JavaScript Fr…

浪潮云启操作系统(InLinux)bcache缓存实践:理解OpenStack环境下虚拟机卷、Ceph OSD、bcache设备之间的映射关系

前言 在OpenStack平台上,采用bcache加速ceph分布式存储的方案被广泛用于企业和云环境。一方面,Ceph作为分布式存储系统,与虚拟机存储卷紧密结合,可以提供高可用和高性能的存储服务。另一方面,bcache作为混合存储方案&…

Turn-it:优化线材重构雕塑制造

🐨文章摘要abstract 电线雕塑在工业应用和日常生活中都很重要。 本文提出了一种新的制造策略,通过调整目标形状以适应电线弯曲机,然后由人工将其弯曲回目标形状。(机器弯曲人工弯曲) 该方法通过两阶段弯曲策略实现&a…

力扣——用队列实现栈(C语言)

目录 题目: 原理: 结构体MyStack 出栈void myStackPop(MyStack* obj) 入栈void myStackPush(MyStack* obj, int x) 读取栈顶元素int myStackTop(MyStack* obj) 判断栈空bool myStackEmpty(MyStack* obj) 销毁栈void myStackFree(MyStack* obj) 整…

NewStar CTF 2024 Week1,Week2部分

WP部分学习官方解题思路&#xff0c;这次比赛还是收获满满呀 web方向&#xff1a; headach3 抓包拿到flag 会赢吗 第一关&#xff1a; 查看源码看到flag第一部分和目录 第二关&#xff1a; 查看js文件 revealflag方法传入了一个className参数 <script>async func…

8.three.js相机详解

8.three.js相机详解 1、 认识相机 在Threejs中相机的表示是THREE.Camera&#xff0c;它是相机的抽象基类&#xff0c;其子类有两种相机&#xff0c;分别是正投影相机THREE.OrthographicCamera和透视投影相机THREE.PerspectiveCamera&#xff1a; 正投影和透视投影的区别是&am…

燕山大学23级经济管理学院 10.18 C语言作业

燕山大学23级经济管理学院 10.18 C语言作业 文章目录 燕山大学23级经济管理学院 10.18 C语言作业1C语言的基本数据类型主要包括以下几种&#xff1a;为什么设计数据类型&#xff1f;数据类型与知识体系的对应使用数据类型时需要考虑的因素 21. 逻辑运算符2. 真值表3. 硬件实现4…

最大公约数(公式法)

求多个数的最大公约数 采用连续求gcd的方式 题目 ACCODE #include<bits/stdc.h> using namespace std; long long num[4]; int main(){cin>>num[1]>>num[2]>>num[3];sort(num1,num4);// cout<<num[1]<<" "<<num[2]<&…

尚硅谷spark学习

p4 快速上手 -开发环境准备

Java多线程新手指南:从零开始学习多线程创建,有两下子!

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴 bug菌&#xff0c;今天又来给大家手把手教学Java SE系列知识点啦&#xff0c;赶紧出来哇&#xff0c;别躲起来啊&#xff0c;听我讲干货记得点点赞&#xff0c;赞多了我就更有动力讲得更欢哦&#xff01;所以呀&…

代码审计-Python Flask

1.Jinjia2模版注入 Flask是一个使用 Python 编写的轻量级 Web 应用框架。其 WSGI 工具箱采用 Werkzeug &#xff0c;模板引擎则使用 Jinja2。jinja2是Flask作者开发的一个模板系统&#xff0c;起初是仿django模板的一个模板引擎&#xff0c;为Flask提供模板支持&#xff0c;由于…

KASan部署、使用与原理分析

文章目录 前言1、概述2、使用方法3、测试用例3.1、检测加载的内核模块3.2、检测调用的内核模块3.3、通过系统调用检测3.4、检测编译到Linux内核中的内核模块 4、工作原理4.1、影子内存&#xff08;Shadow Memory&#xff09;4.2、内存状态&#xff08;Memory States&#xff09…

海南聚广众达电子商务咨询有限公司靠谱吗怎么样?

在当今这个数字化浪潮席卷全球的时代&#xff0c;抖音电商以其独特的魅力成为了众多商家争相入驻的新蓝海。而在这片浩瀚的电商海洋中&#xff0c;如何找到一家既专业又可靠的合作伙伴&#xff0c;成为了众多商家心中的一大难题。今天&#xff0c;我们就来深入剖析一下海南聚广…

爬虫日常实战

爬取美团新闻信息&#xff0c;此处采用两种方法实现&#xff1a; 注意点&#xff1a;因为此处的数据都是动态数据&#xff0c;所以一定要考虑好向下滑动数据包会更新的情况&#xff0c;不然就只能读取当前页即第一页数据&#xff0c;方法一通过更新ajax数据包网址页数&#xf…

转变软件交付方式:通过统一 API 和测试策略提高质量和速度

API 在当今的数字化转型中至关重要&#xff0c;但无缝交付也同样重要。然而&#xff0c;许多组织仍然分散其 API 开发和 UI 测试流程&#xff0c;导致问题检测延迟、发布时间延长&#xff0c;甚至遗漏错误。在快节奏的环境中&#xff0c;这种方法是不可持续的&#xff0c;因为上…

Java调用上传文件接口

以 QAnthing 上传文件&#xff08;POST&#xff09;接口为例&#xff0c;展示Java如何调用上传文件接口。 接口文档如下&#xff1a; QAnthign接口文档地址 上代码&#xff1a; RestTemplate 版 /** * * param url 接口地址 * param filePath 文件本地路径 */ public vo…

【C++】踏上C++学习之旅(三):“我“ 与 “引用“ 的浪漫邂逅

文章目录 前言1. "引用"的概念1.1 "引用"的语法 2. "引用"的特性3. "引用"的使用场景3.1 "引用"做参数3. 2 "引用"做返回值3.2.1 "引用"做返回值时需要注意的点 4. 常引用5. "引用"在底层的实…

【设计模式系列】命令模式

目录 一、什么是命令模式 二、命令模式的角色 三、命令模式的典型应用场景 四、命令模式在Runnable中的应用 一、什么是命令模式 命令模式&#xff08;Command Pattern&#xff09;是一种行为设计模式&#xff0c;它将一个请求或简单操作封装为一个对象。这个模式提供了一种…