【sql】MongoDB 新增 高级用法

【sql】MongoDB 新增 高级用法




批量插入数据, 遇到错误跳过并继续执行


方案一

ordered:false

使用场景:

1: 数据存在时则跳过插入

//批量插入

db.res_phone.insertMany(

[

{"_id":1, "phone":10086},

{"_id":2, "phone":10010},

{"_id":3, "phone":10000},

],

{

//遇到错误是否中断 false遇到错误会跳过 继续执行

ordered:false

}

);


方案二

update里有个参数 'setOnInsert' 可以实现"存在则不执行"的功能,可见 setOnInsert 官方文档。

示例:

起始数据:

|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| > db.Blog.``insert``({``"_id"``:``"123456"``, ``"blog_cont"``:``"abcdef"``, ``"title"``:``"《My Test》"``}) > db.Blog.find() { ``"_id" : ``"123456"``, ``"blog_cont" : ``"abcdef"``, ``"title" : ``"《My Test》" } |

加入相同 ID 的日志:

|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| > db.Blog.``update``({``"_id"``:``"123456"``}, {$setOnInsert:{``"blog_cont"``:``"abc123"``, ``"other"``:``"hello world!"``}}, {upsert:``true``}) WriteResult({ ``"nMatched" : 1, ``"nUpserted" : 0, ``"nModified" : 0 }) > > db.Blog.find() { ``"_id" : ``"123456"``, ``"blog_cont" : ``"abcdef"``, ``"title" : ``"《My Test》" } |

加入不同 ID 的日志:

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| > db.Blog.``update``({``"_id"``:``"123"``}, {$setOnInsert:{``"blog_cont"``:``"abc123"``, ``"other"``:``"hello world!"``}}, {upsert:``true``}) WriteResult({ ``"nMatched" : 0, ``"nUpserted" : 1, ``"nModified" : 0, ``"_id" : ``"123" }) > > db.Blog.find() { ``"_id" : ``"123456"``, ``"blog_cont" : ``"abcdef"``, ``"title" : ``"《My Test》" { ``"_id" : ``"123"``, ``"blog_cont" : ``"abc123"``, ``"other" : ``"hello world!" } |

如果某些内容想更新的话(例如更新 title )可以用 '$set':

|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| > db.Blog.``update``({``"_id"``:``"123456"``}, {$setOnInsert:{``"blog_cont"``:``"abc123"``, ``"other"``:``"hello world!"``}, $``set``:{``"title"``:``"《New Title》"``}}, {upsert:``true``}) WriteResult({ ``"nMatched" : 1, ``"nUpserted" : 0, ``"nModified" : 1 }) > > db.Blog.find() { ``"_id" : ``"123456"``, ``"blog_cont" : ``"abcdef"``, ``"title" : ``"《New Title》 { "``_id``" : "``123``", "``blog_cont``" : "``abc123``", "``other``" : "``hello world!" } |


相关推荐
葫芦和十三9 小时前
图解 MongoDB 19|Oplog:复制的真正载体,不是文档是操作
后端·mongodb·agent
葫芦和十三9 小时前
图解 MongoDB 20|复制延迟与 catch up:Secondary 为什么跟不上
后端·mongodb·agent
GBASE14 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
葫芦和十三2 天前
图解 MongoDB 17|大集合与工作集:数据超过内存怎么办
后端·mongodb·面试
葫芦和十三2 天前
图解 MongoDB 18|复制集拓扑:Primary、Secondary 和 Arbiter 的分工
后端·mongodb·面试
葫芦和十三3 天前
图解 MongoDB 15|journal 与持久化:写入怎么不丢,崩溃怎么恢复
后端·mongodb·面试
葫芦和十三3 天前
图解 MongoDB 16|压缩:snappy、zstd 和 zlib 的取舍
后端·mongodb·面试