Mongodb操作与Java(三)增删改语句及DDL新增或删除字段

MongoDB概念

MongoDB 基本概念指的是学习 MongoDB 最先应该了解的词汇,比如 MongoDB 中的"数据库"、"集合"、"文档"这三个名词:

文档(Document): 文档是 MongoDB 中最基本的数据单元,由键值对组成,类似于 JSON 格式,可以存储不同字段,字段的值可以包括其他文档,数组和文档数组。(相当于mysql每一行就是一个文档)

集合(Collection): 集合指的是文档组(类似于 Mysql 中的表的概念),里面可以存储许多文档。

数据库(Database): MongoDB 中可以存在多个数据库,每个数据库中中用有不同的集合与用户权限,这样可以供不同的项目组使用不同的数据库。

基础增删改

插入单个文档:

db.collection.insertOne({
name: "John Doe",
age: 30,
email: "john.doe@example.com"
});

插入多个文档

db.collection.insertMany([

{ name: "Alice", age: 25, email: "alice@example.com" },

{ name: "Bob", age: 28, email: "bob@example.com" }

]);

删除单个文档

db.collection.deleteOne({ name: "John Doe" });

删除多个文档

db.collection.deleteMany({ age: { $lt: 30 } });

更新单个文档

这条命令查找第一个匹配的 name: "John Doe" 的文档,并更新其 age 字段。

db.collection.updateOne(

{ name: "John Doe" }, // 查询条件

{ $set: { age: 31 } } // 更新操作

);

更新多个文档

这条命令查找所有 age 小于 30 的文档,并更新它们的 status 字段。

db.collection.updateMany(

{ age: { $lt: 30 } }, // 查询条件

{ $set: { status: "young" } } // 更新操作

);

新增或删除字段

新增字段

MongoDB 是基于文档的,所以不存在传统意义上的"新增字段"。你简单地向文档中添加新的键值对即可。这意味着如果你想在某个集合的文档中添加新字段,你只需在插入或更新文档时包含该字段。例如,如果你想给现有文档添加一个 phoneNumber 字段,你可以使用如下命令:

db.collection.updateMany(

{}, // 查询条件,空对象{}表示更新所有文档

{ $set: { phoneNumber: "123-456-7890" } } // 添加phoneNumber字段

);

这条命令会向集合中的所有文档添加一个 phoneNumber 字段。

删除字段

删除一个字段需要使用 $unset 操作符。这个操作符会从匹配的文档中移除指定的字段。例如,如果你决定从文档中删除 phoneNumber 字段,可以执行以下命令:

db.collection.updateMany(

{}, // 查询条件,空对象{}表示更新所有文档

{ $unset: { phoneNumber: "" } } // 删除phoneNumber字段 ,指定要删除的字段,值可以是空字符串或1

);

相关推荐
像污秽一样3 分钟前
Spring MVC初探
java·spring·mvc
计算机-秋大田4 分钟前
基于微信小程序的乡村研学游平台设计与实现,LW+源码+讲解
java·spring boot·微信小程序·小程序·vue
LuckyLay6 分钟前
Spring学习笔记_36——@RequestMapping
java·spring boot·笔记·spring·mapping
Watermelo6178 分钟前
通过MongoDB Atlas 实现语义搜索与 RAG——迈向AI的搜索机制
人工智能·深度学习·神经网络·mongodb·机器学习·自然语言处理·数据挖掘
哭哭啼23 分钟前
Redis环境部署(主从模式、哨兵模式、集群模式)
数据库·redis·缓存
咕噜Yuki060937 分钟前
OCP证书如何下载?
数据库·ocp·证书查询
醉颜凉43 分钟前
【NOIP提高组】潜伏者
java·c语言·开发语言·c++·算法
阿维的博客日记1 小时前
java八股-jvm入门-程序计数器,堆,元空间,虚拟机栈,本地方法栈,类加载器,双亲委派,类加载执行过程
java·jvm
qiyi.sky1 小时前
JavaWeb——Web入门(8/9)- Tomcat:基本使用(下载与安装、目录结构介绍、启动与关闭、可能出现的问题及解决方案、总结)
java·前端·笔记·学习·tomcat
lapiii3581 小时前
图论-代码随想录刷题记录[JAVA]
java·数据结构·算法·图论