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

);

相关推荐
pengdott5 小时前
Oracle RAC内存融合技术深度解析:集群性能的幕后引擎
数据库·oracle
csudata6 小时前
绿色便携版PostgreSQL发行版重磅发布
数据库·postgresql
阳光九叶草LXGZXJ7 小时前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习
Hx_Ma167 小时前
SpringMVC框架提供的转发和重定向
java·开发语言·servlet
我科绝伦(Huanhuan Zhou)7 小时前
脚本再升级,兼容Oracle 26ai一键安装
数据库·oracle
期待のcode7 小时前
原子操作类LongAdder
java·开发语言
野生绿箭侠8 小时前
Ncos 2.3.2 版本集成达梦数据库
数据库
舟舟亢亢8 小时前
Java集合笔记总结
java·笔记
仍然.8 小时前
MYSQL--约束
数据库·mysql
小酒窝.8 小时前
【多线程】多线程打印ABC
java