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

MongoDB概念

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

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

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

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

基础增删改

插入单个文档:

db.collection.insertOne({
name: "John Doe",
age: 30,
email: "[email protected]"
});

插入多个文档

db.collection.insertMany([

{ name: "Alice", age: 25, email: "[email protected]" },

{ name: "Bob", age: 28, email: "[email protected]" }

]);

删除单个文档

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

);

相关推荐
DougLiang32 分钟前
关于easyexcel动态下拉选问题处理
java·开发语言
mochensage41 分钟前
C++信息学竞赛中常用函数的一般用法
java·c++·算法
计蒙不吃鱼1 小时前
一篇文章实现Android图片拼接并保存至相册
android·java·前端
卜及中1 小时前
【Redis/2】核心特性、应用场景与安装配置
数据库·redis·缓存
小海编码日记1 小时前
Java八股-JVM & GC
java
全职计算机毕业设计1 小时前
基于Java Web的校园失物招领平台设计与实现
java·开发语言·前端
东阳马生架构1 小时前
商品中心—1.B端建品和C端缓存的技术文档
java
Chan161 小时前
【 SpringCloud | 微服务 MQ基础 】
java·spring·spring cloud·微服务·云原生·rabbitmq
LucianaiB1 小时前
如何做好一份优秀的技术文档:专业指南与最佳实践
android·java·数据库
Eiceblue2 小时前
Python读取PDF:文本、图片与文档属性
数据库·python·pdf