【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!" } |


相关推荐
葫芦和十三5 小时前
图解 MongoDB 05|文档模型设计:内嵌 vs 引用,反范式不是免费午餐
后端·mongodb·agent
zzzzzz31020 小时前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
葫芦和十三21 小时前
图解 MongoDB 03|CRUD 全链路:一条 find 怎么穿过 WiredTiger
后端·mongodb·agent
葫芦和十三1 天前
图解 MongoDB 04|索引模型:每建一个索引,就是在 B+-tree 森林里多栽一棵
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 02|BSON:你以为存的是 JSON,其实是带类型的二进制
后端·mongodb·agent
葫芦和十三2 天前
图解 MongoDB 01|文档数据库
后端·mongodb·agent
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab3 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle