mongodb-常用命令

1.要从MongoDB中删除不在某个列表中的数据,您可以使用聚合管道的 `expr\` 操作符和 \`nin` 操作符

以下是一个示例,假设您有一个名为 `students` 的集合,其中包含一个 `name` 字段,您想要删除不在 `['Alice', 'Bob', 'Charlie']` 列表中的学生。

cs 复制代码
db.getCollection("semp_work_order_active").find({"orderCode" : { $in : ['DW-1311-20240525-9744150528000','DW-1311-20240522-8954433536000','DW-1311-20240522-9751815168000'] }}).limit(100000).skip(0)


db.getCollection("semp_work_order_active").remove( { _id: ObjectId("66513e3a491b0637bec40fa1") }, { justOne: true } )

在上面的示例中,`$$name` 是聚合管道中的变量,代表当前文档的 `name` 字段。`$nin` 操作符检查 `name` 是否不在 `['Alice', 'Bob', 'Charlie']` 列表中。

执行上面的命令后,所有不在 `['Alice', 'Bob', 'Charlie']` 列表中的学生将会被删除。

2.MongoDB中统计总数

db.semp_alarm_active.count()

3.mogodb删除数据

要从MongoDB中删除不在某个列表中的数据,您可以使用聚合管道的 $expr 操作符和 $nin 操作符。

以下是一个示例,假设您有一个名为 students 的集合,其中包含一个 name 字段,您想要删除不在 ['Alice', 'Bob', 'Charlie'] 列表中的学生。

复制代码
db.students.deleteMany(
  {
    $expr: { $nin: ['$$name', ['Alice', 'Bob', 'Charlie']] }
  }
)

在上面的示例中,$$name 是聚合管道中的变量,代表当前文档的 name 字段。$nin 操作符检查 name 是否不在 ['Alice', 'Bob', 'Charlie'] 列表中。

执行上面的命令后,所有不在 ['Alice', 'Bob', 'Charlie'] 列表中的学生将会被删除。

4.mongodb批量插入数据

在MongoDB中,批量插入数据可以通过以下几种方式实现:

  1. 使用`insertMany()`方法:

```javascript

const collection = db.get('myCollection');

const documents = [

{ name: 'John', age: 20 },

{ name: 'Jane', age: 25 },

{ name: 'Bob', age: 30 }

];

collection.insertMany(documents);

```

  1. 使用`bulkWrite()`方法:

```javascript

const collection = db.get('myCollection');

const operations = [

{ insertOne: { document: { name: 'John', age: 20 } } },

{ insertOne: { document: { name: 'Jane', age: 25 } } },

{ insertOne: { document: { name: 'Bob', age: 30 } } }

];

collection.bulkWrite(operations);

```

  1. 使用`forEach()`方法和`insertOne()`方法:

```javascript

const collection = db.get('myCollection');

const documents = [

{ name: 'John', age: 20 },

{ name: 'Jane', age: 25 },

{ name: 'Bob', age: 30 }

];

documents.forEach(document => collection.insertOne(document));

```

以上三种方法都可以实现批量插入数据,选择哪种方法取决于你的具体需求和喜好。

相关推荐
PyHaVolask6 小时前
SQL注入漏洞原理
数据库·sql
ptc学习者6 小时前
黑格尔时代后崩解的辩证法
数据库
代码游侠6 小时前
应用——智能配电箱监控系统
linux·服务器·数据库·笔记·算法·sqlite
!chen6 小时前
EF Core自定义映射PostgreSQL原生函数
数据库·postgresql
霖霖总总6 小时前
[小技巧14]MySQL 8.0 系统变量设置全解析:SET GLOBAL、SET PERSIST 与 SET PERSIST_ONLY 的区别与应用
数据库·mysql
马克学长6 小时前
SSM校园食堂订餐系统531p9(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·ssm 校园食堂订餐系统
alonewolf_996 小时前
深入剖析MySQL索引底层:B+树、联合索引与跳跃扫描原理全解
数据库·b树·mysql
oMcLin7 小时前
如何在 AlmaLinux 9 上配置并优化 Redis 集群,支持高并发的实时数据缓存与快速查询?
数据库·redis·缓存
洛阳纸贵7 小时前
Redis
数据库·redis·缓存
l1t7 小时前
DeepSeek辅助编写的利用位掩码填充唯一候选数方法求解数独SQL
数据库·sql·算法·postgresql