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

);

相关推荐
人活一口气18 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP20 小时前
Vibe Coding -- 完整项目案例实操
java
荣码20 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing20 小时前
Google第三方授权登录
java·后端·程序员
明月光81820 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
葫芦和十三1 天前
图解 MongoDB 22|读写关注:持久性与一致性的档位选择
后端·mongodb·agent
葫芦和十三1 天前
图解 MongoDB 21|选举与 failover:Primary 是怎么选出来的
后端·mongodb·agent
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路1 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java