RethinkDB:​​更新文档

时间:2015-11-20 23:53:40

标签: rethinkdb

这是一个远景,但我想知道是否在rethinkDB中,假设我更新了一个文档。是否有一个神奇的函数,如果它是一个字符串或int,它只是更新它,但如果字段的值是一个数组,它会将它附加到数组?

2 个答案:

答案 0 :(得分:3)

在这种情况下,您需要使用.branch并对该类型进行分支。像.update(function(row) { return {field: r.branch(row('field').typeOf().eq('ARRAY'), row('field').add([el]), el)}; })

这样的东西

答案 1 :(得分:2)

有一个神奇的功能可以做类似的事情。 .forEach具有添加数字,组合数组和删除字符串的未记录行为:

>>> r.expr([{a:1, b:[2], c:"3"}, {a:2, b:[4], c:"6"}]).forEach(r.row)
{"a": 3, "b": [2,4], "c": "3"}