MongoDB的安装与增删改查基本操作

MongoDB是一种非关系型数据库,是NoSQL语言,但是又是最接近关系型数据库的。内部存储不是表结构,但是可以对数据进行表结构的操作。

一、安装

在官网:Download MongoDB Community Server | MongoDB下载系统对应的版本进行安装即可


二、编辑器

在安装MongoDB后会自带一个编辑器,如果你不想用,可以跟我一样下载一个其他的编辑器,我用的是:Studio 3T,官网下载:Robo 3T | Free, open-source MongoDB GUI (formerly Robomongo)


三、Studio 3T链接MongoDB

 

然后我们就可以进行一些连接的设置: 

最后保存再链接即可


四、MongoDB对库的操作

以下操作是在命令提示符窗口操作,使用编辑器的可视化界面操作也可以。

在编辑器中打开命令提示符窗口:

1、增

use 库名

2、删

首先保证你当前操作的数据库是你要删除的数据库,然后执行:

db.dropDatabase()

3、查 

查看数据库:

show 库名

五、MongoDB对集合的操作

1、增

添加一个集合

db.createCollection("stuent")

上述代码实现了增加一个集合名为student 

2、删

删除一个集合

db.集合名.drop()

3、查

查看集合 :

show collections

查看集合记录数量

db.集合名.count()

 查看数据空间容量,单位字节

db.student.dataSize()

4、改 

重命名集合

db.原集合名.renameCollection(“新集合名”)

六、MongoDB对数据的操作 

1、增

添加一行数据(insertOne)

db.student.insertOne({name:"jack",age:30})

上述代码是对student集合插入了一条数据,name是Jack,age是30。

添加多行数据(insertMany)

db.student.insertMany([{name:"jette",age:30},{name:"t_t",age:30}])

上述代码是对student集合插入了两条数据,每条数据用花括号包裹,多条数据之间用逗号间隔。

添加多行或一行(insert)

db.student.insert([{name:"周瑜",sex:"男",age:19,birthday:"2004-10-22",city:"北京",class:"5-1"},
{name:"诸葛亮",sex:"男",age:20,birthday:"2004-10-22",city:"北京",class:"5-1"},
{name:"曹操",sex:"男",age:28,birthday:"2004-10-22",city:"上海",class:"5-1"}])

上述代码对student集合添加了三条数据

2、删

删除记录(remove)

db.student.remove({class:
"2-6",sex:
"男"})

上述代码实现了对class列的值为2-6的男生记录进行了删除。

3、改

update({修改的目标记录属性条件},{修改的值})修改一条

updateMany({修改的目标记录属性条件},{修改的值})修改一条或多条

db.student.update({name:"周瑜"},{$set:{age:30}})

上述代码实现了对student集合的name值为周瑜的记录的age值修改为30。

4、查

find()

无条件查询:

db.集合名.find()

上述代码会将目标集合中的所有记录都查询出来。

有条件查询:

例如我们要查询name值为周瑜的:

db.student.find({name:"周瑜"})

多个条件用逗号分开:

db.student.find({name:"诸葛亮",sex:"男"})

上述代码实现了对name值为诸葛亮的,sex值为男的记录进行查询。

条件表达式:

1、$lt:(小于)或$gt:(大于)

例如:查询年龄小于12的记录

db.集合名.find({age:{$lt:12}})
2、$lte(小于等于)或$gte(大于等于)
3、$in(包括)$nin(不包括)

例如:查询city字段值为上海或北京的

db.student.find({city:{$in:["北京","上海"]}})
4、$ne(不等于)

例如:查询city值不为北京的:

db.student.find({city:{$ne:"北京"}})
5、$all(全部)

查询到的记录至少满足all内的所有条件,也就是all内的条件全都要满足

例如:查询职位既是班主任又是年级主任的记录:

db.teacher.find({role:{$all:["班主任","年级主任"]}})
6、$not(全不)

用于反转查询表达式的结果。换句话说,它表示“不匹配”或“不是”的逻辑。

例如:查询年龄不是大于30小于34的记录:

db.集合名.find({age:{$not:{$gte:30,$lt:34}}})
7、$or(或)

例如:查询30岁以下的男学生,或者25岁以下的女学生

db.student.find({
$or:[{age:{$1t:30},sex:"男"},{age:{$1t:25},sex:"女"}]
})
8、$exists(存在字段)

这个是用于判断记录有没有这个字段的

例如:查询没有class字段的记录

db.student.find({class:{$exists:0}})

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握CMD命令:轻松切换IP地址

在日常的网络管理与维护中,切换IP地址是一项常见且重要的操作。无论是为了测试网络配置、访问特定资源,还是解决IP冲突问题,掌握如何在命令行界面(CMD)中切换IP地址都是每个网络管理员或高级用户的必备技能。本文将详细…

asp.net mvc core 路由约束,数据标记DataTokens

》从0自己搭建MVC 》用 asp.net Core web 应用 空web 应用程序 需要配置 mvc服务 、mvc路由 新建 Controller 、Models、Views 》》》core 6 之前版本 vs2022 asp.net Core Web 应用(模型-视图-控制器) 不需要配置 就是mvc框架 asp.net Core web 应…

怎么查看网站是否被谷歌收录,查看网站是否被搜索引擎收录5个方法与步骤

要查看网站是否被谷歌(Google)或其他搜索引擎收录,是网站管理和SEO(搜索引擎优化)中的一个重要环节。以下是查看网站是否被搜索引擎收录5个方法与步骤,帮助您确认网站是否被搜索引擎成功索引: …

丹摩智算(damodel)部署stable diffusion实验

名词解释: 丹摩智算(damodel):是一款带有RTX4090,Tesla-P40等显卡的公有云服务器。 stable diffusion:是一个大模型,可支持文生图,图生图,文生视频等功能 一.实验目标 …

八LAMP搭建

# LAMP ## 一、知识回顾 ### FTP samba nfs 特点 - 借用Linux用户作为映射用户,进行权限管理 - 软件本身还有管理控制权限 #### 客户端连接到服务器后进行读写执行等操作 ,必须同时具有: - 软件许可的权限 vsftpd: anon upload enableYES - 文件…

零工市场小程序如何提高找兼职的效率?

越来越多的人们会选择成为自由职业者,或者在空暇时兼职来获取酬劳,那么传统的找兼职方式,如:中介公司、招聘广告等。 如今大家的生活都已经进入了“快节奏”,零工市场小程序针对这样的问题而提出了解决方案&#xff0…

侧边菜单的展开和折叠

环境准备&#xff1a;Vue3Element-UI Plus <script setup> import {ref} from "vue";// 是否折叠菜单&#xff0c;默认折叠 const isCollapse ref(true)// 退出登录 function logout() {alert(退出) }// 个人中心 function profile() {alert(个人中心) } <…

ping基本使用详解

在网络中ping是一个十分强大的TCP/IP工具。它的作用主要为&#xff1a; 用来检测网络的连通情况和分析网络速度根据域名得到服务器 IP根据 ping 返回的 TTL 值来判断对方所使用的操作系统及数据包经过路由器数量。我们通常会用它来直接 ping ip 地址&#xff0c;来测试网络的连…

【2024.9.29练习】R 格式

题目描述 题目分析 带小数点的高精度乘法。小数点在计算时忽略&#xff0c;只需在最终打印字符串的时候在合适位置四舍五入即可。对于&#xff0c;可理解为对d乘2总共n次。因此使用“单精度高精度”类型的算法足矣。 我的代码 一开始代码有错误&#xff0c;我只想到了对小数点…

AI大模型之旅-最强开源文生图工具Stable Diffusion WebUI 教程

1.1克隆 Automatic1111 的 GitHub 仓库 在你想安装 Web UI 的文件夹路径下执行 git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui 这将会克隆整个仓库到本地。 这里会默认访问 https://huggingface.co/ 下载 因此需要魔法 1.2 进入仓库目录 cd stable-di…

无人机培训机构配套教学无人机技术详解

无人机培训机构配套的教学无人机技术&#xff0c;是一个涉及多学科交叉、技术密集型的领域。以下是对该技术的详细解析&#xff1a; 一、无人机技术概述 无人机技术是一个涵盖航空工程、电子工程、计算机科学、材料科学和人工智能等多个学科的综合性领域。其核心在于实现无人…

python并发编程实战

python并发编程有三种 多线程Thread多进程Process多协程Coroutine cpu密集型计算 cpu密集型也叫计算密集型&#xff0c;是指I/O在很短的时间就可以完成&#xff0c;cpu需要大量的计算处理&#xff0c;特点是cpu占用率相当高 例如&#xff1a;压缩解压缩、加密解密、正则表达…

Redis:持久化

1. Redis持久化机制 Redis 支持 RDB 和 AOF 两种持久化机制&#xff0c;持久化功能有效地避免因进程退出造成数据丢失问题&#xff0c; 当下次重启时利⽤之前持久化的文件即可实现数据恢复。 2.RDB RDB 持久化是把当前进程数据⽣成快照保存到硬盘的过程&#xff0c;触发 RDB…

从AR眼镜到智能巡检:XR技术的演变与未来潜力

XR&#xff0c;即扩展现实&#xff08;Extended Reality&#xff09;&#xff0c;是一个涵盖了增强现实&#xff08;AR&#xff09;、虚拟现实&#xff08;VR&#xff09;和混合现实&#xff08;MR&#xff09;的广泛概念。 从我们最初接触到的手机应用到Hololens&#xff0c;…

Linux 网络配置 (深入理解)

前言 前期我比较迷惑Ubuntu 的网络配置。 我接触比较多的 Linux 发行版都是 Ubuntu &#xff0c;我按照网上的一些教程配置网络发现&#xff0c;没有相关网络配置文件夹。然后我发现不是我的问题而是不同版本的配置方式和工具是不一样的。然后有些配置已经弃用了。 常见的网络…

fmql之Linux异步通知

正点原子第35章。 Linux下的异步通知_linux异步通知-CSDN博客 异步通知简介 驱动中的信号处理 应用程序对异步通知的处理 代码 async.c asyncAPP.c 运行

作家依靠AI一年内创作120部作品

近期&#xff0c;Tim Boucher因声称自己依托人工智能&#xff08;AI&#xff09;完成了逾120部作品而在社交网络上引起广泛关注。 Boucher的这种创作手法引发了众多讨论和争议。一些批评者对他依靠AI写作表示不满&#xff0c;认为这种做法缺乏诚实性&#xff0c;甚至涉嫌抄袭。…

利用git将项目上传到github

采用git而不是在pycharm中共享的原因&#xff1a;可能会出现上图报错 目录 1、创建github仓库2、在 git bash 中初始化Git仓库&#xff0c;添加文件&#xff0c;上传代码 1、创建github仓库 2、在 git bash 中初始化Git仓库&#xff0c;添加文件&#xff0c;上传代码

基于CNN+Transformer混合模型实现交通流量时序预测(PyTorch版)

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域&#xff0c;讨论了各种复杂的深度神经网络思想&#xff0c;如卷积神经网络、循环神经网络、生成对…

Ansible集群服务部署案例

案例描述 本案例共讲述了多个节点部署Elk集群日志分析系统&#xff0c;分别在三个节点使用ansible部署Kibana、Logstash以及Elasticsearch服务。 案例准备 1. 规划节点 IP 主机名 节点 192.168.100.25 ansible Ansible节点 192.168.100.35 node1 Elasticsearch/Kiba…