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

news2024/12/23 18:43:27

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.coloradmin.cn/o/2185400.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

html+css+js实现Collapse 折叠面板

实现效果&#xff1a; HTML部分 <div class"collapse"><ul><li><div class"header"><h4>一致性 Consistency</h4><span class"iconfont icon-jiantou"></span></div><div class"…

UFS 3.1架构简介

整个UFS协议栈可以分为三层:应用层(UFS Application Layer(UAP)),传输层(UFS Transport Layer(UTP)),链路层(UIC InterConnect Layer(UIC))。应用层发出SCSI命令(UFS没有自己的命令使用的是简化的SCSI命令),在传输层将SCSI分装为UPIU,再经过链路层将命令发送给Devices。下…

通信工程学习:什么是TCP传输控制协议

TCP&#xff1a;传输控制协议 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是因特网协议套件中最重要的协议之一&#xff0c;它为应用程序提供了可靠、面向连接的通信服务。以下是TCP协议的详细解释&#xff1a; 一、TCP传输控制协议的…

双十一有哪些值得入手的好物?这五款宝藏好物不容错过!

在这个金秋送爽、收获满满的季节里&#xff0c;我们迎来了万众瞩目的双十一购物狂欢节。这不仅仅是一场简单的消费盛宴&#xff0c;更是每一位消费者期待已久、精心筹备的年度购物盛典。随着电商平台的不断革新与优惠力度的持续加码&#xff0c;双十一已经从一个简单的促销日成…

使用百度文心智能体创建多风格表情包设计助手

文章目录 一、智能定制&#xff0c;个性飞扬二、多元风格&#xff0c;创意无限 百度文心智能体平台为你开启。百度文心智能体平台&#xff0c;创建属于自己的智能体应用。百度文心智能体平台是百度旗下的智能AI平台&#xff0c;集成了先进的自然语言处理技术和人工智能技术&…

单目3d重建DUSt3R 笔记

目录 DUSt3R 三维重建 报错RecursionError: maximum recursion depth exceeded in comparison 报错 numpy.core.multiarray failed to import 报错Numpy is not available 解决 升级版mast3r 速度变慢 修改了参数设置脚本&#xff1a; 测试效果 操作技巧 DUSt3R 三维重…

[已解决] Install PyTorch 报错 —— OpenOccupancy 配环境

目录 关于 常见的初始化报错 环境推荐 torch, torchvision & torchaudio cudatoolkit 本地pip安装方法 关于 OpenOccupancy: 语义占用感知对于自动驾驶至关重要&#xff0c;因为自动驾驶汽车需要对3D城市结构进行细粒度感知。然而&#xff0c;现有的相关基准在城市场…

torchvision.transforms.Resize()的用法

今天我在使用torchvision.transforms.Resize()的时候发现&#xff0c;一般Resize中放的是size或者是(size,size)这样的二元数。 这两个里面&#xff0c;torchvision.transforms.Resize((size,size))&#xff0c;大家都很清楚&#xff0c;会将图像的h和w大小都变成size。 但是…

【python实操】python小程序之过七游戏以及单词单复数分类

引言 python小程序之过7游戏、单词单复数分类 文章目录 引言一、过7游戏1.1 题目1.2 代码1.2.1 while循环1.2.2 for循环1.2.3 调用函数形式 1.3 代码解释 二、单词单复数分类2.1 题目2.2 代码2.3 代码解释 三、思考3.1 过七游戏3.2 单词单复数分类 一、过7游戏 1.1 题目 7的倍…

大模型 LLaMA-Omni 低延迟高质量语音交互,开源!

最近这一两周看到不少互联网公司都已经开始秋招发放Offer。 不同以往的是&#xff0c;当前职场环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;HC 在变少&#xff0c;岗位要求还更高了。 最近&#xff0c;我们又陆续整理了很多大厂的面试题&#xff0c;帮助一些球…

python-patterns:Python 设计模式大全

python-patterns 是一个开源的 Python 项目&#xff0c;它提供了各种经典的设计模式的 Python 实现。设计模式是一种针对常见软件设计问题的可复用解决方案&#xff0c;通过使用设计模式&#xff0c;开发者可以编写出结构更加合理、易于维护和扩展的代码。 Python 是一门动态语…

GraphEval: A Knowledge-Graph Based LLM Hallucination Evaluation Framework

文章目录 题目摘要引言问题陈述相关工作GraphEval:我们的评估方法使用LLM构建知识GraphCorrect:使用GraphEval纠正幻觉实验讨论结论 题目 GraphEval:一个基于知识图的LLM幻觉评估框架 论文地址&#xff1a;https://arxiv.org/abs/2407.10793 摘要 评估大型语言模型(LLM)响应和…

【计算机科研方法指南】- 读书笔记《学术咸鱼自救指南》+于老师科研课

前言简介 因为自己在做计算机科研的时候&#xff0c;一开始很不顺利&#xff0c;所以专门去研究了一些具体的计算机科研方法。这里的方法主要参考了两个资料&#xff0c;一个是《学术“咸鱼”自救指南》&#xff0c;一个是于静老师科研课。 《学术“咸鱼”自救指南》是作者钱…

【微服务】组件、基础工程构建(day2)

组件 服务注册和发现 微服务模块中&#xff0c;一般是以集群的方式进行部署的&#xff0c;如果我们调用的时候以硬编码的方式&#xff0c;那么当服务出现问题、服务扩缩容等就需要对代码进行修改&#xff0c;这是非常不好的。所以微服务模块中就出现了服务注册和发现组件&…

视频创作黑科技!CogVideoX秒生成艺术视频

视频创作黑科技&#xff01;CogVideoX秒生成艺术视频 CogVideoX上线啦&#xff01;&#x1f389; 它能把文字和图片变成惊艳视频&#x1f3a5;。CogVideoX-5B如同好莱坞导演&#xff0c;快速生成高质量内容⚡&#xff0c;完美捕捉创意细节✨。让你轻松成为视频创作大师&#x…

Linux命令--03----帮助类命令、开关机类命令

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.帮助类命令man获取帮助信息help获得shell内置命令的帮助信息 2.开关机类命令2.1 开关机命令一般Linux不会经常进行关机操作,正确的关机流程为: sync>shutdown&…

初识TCP/IP协议

回顾上文 来回顾一下TCP协议的特性&#xff0c;有一道比较经典的题&#xff1a;如何使用UDP实现可靠传输&#xff0c;通过应用程序的代码&#xff0c;完成可靠传输的过程&#xff1f; 原则&#xff0c;TCO有啥就吹啥&#xff0c;引入滑动窗口&#xff0c;引入流量控制&#x…

电子连接器温升仿真教程 二

在《电子连接器温升仿真教程 一》中详细介绍了用内热法做电子连接器温升仿真的操作步骤与方法,本教程将讲解用电流电压法做电子连接器温升仿真。 本教程,将以下面产品为例演示温升仿真方法其操作步骤。 该连接器为电池连接器,其Housing材料为LCP+30%GF,端子材质为铍铜…

IDEA中配置启动类的Active Profiles

如现在有以下三个配置文件 application.yaml application-dev.yaml application-local.yaml 当我在本机启动时&#xff0c;想使用application-local.yaml&#xff0c;而不是application-dev.yaml&#xff0c;那么可以这样配置&#xff1a;&#xff08;我这是添加启动类一起的&a…

基于深度学习的乳腺癌分类识别与诊断系统

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 乳腺癌是全球最常见的癌症之一&#xff0c;早期诊断对于治疗效果至关重要。近年来&#xff0c;深度学习技术在医学图像分析领域取得了显著进展&#xff0c;能够从大量的医学影像数据中自动学习和提…