我有一个.itemId
来自第 3 方的,不是由我生成的。
如果不存在,我需要在数据库中查找并更新或插入它。
我试过使用食谱中的这个例子:https ://www.rethinkdb.com/docs/cookbook/javascript/#manipulating-documents
const res = await this.r.table('products').filter({itemId: item.itemId})
.limit(1)
.replace(doc => {
return this.r.branch(
doc.eq(null),
this.r.expr(item).merge({created_at: this.r.now()}),
doc.merge(item).merge({updated_at: this.r.now()})
)
}, {
returnChanges: true
}).run(this.conn);
if (res.replaced) {
return res.changes[0].new_val;
} else {
return item; // doc was never inserted as everything in `res` is `0`.
}
res.changes
如果文档不存在并且我在它不在数据库中之后搜索 id,则未定义。它从未被插入。
upsert()
给定对象的任意属性,有没有办法简化命令?