nested - 嵌套 N1QL 更新查询
问题描述
我搜索了一些先前的线程,但根据我如何为 Couchbase 实现 N1QL 更新查询,我无法弄清楚我做错了什么。我正在运行以选择目标更新的查询运行良好:
SELECT p FROM `NoSQLDB` AS c UNNEST c.phones as p
WHERE c.type='com.model' AND p.typeCode != 'B_BUS'
这提供了以下结果:
[
{
"p": {
"type": "com.model.Phone",
"typeCode": "H_HOME",
}
},
{
"p": {
"type": "com.model.Phone",
"typeCode": "H_HOME",
}
}
]
这是我要更新的数据,但是,当我使用以下更新语句更新 typeCode 时,它会执行但实际上并没有改变任何东西:
UPDATE `NoSQLDB` AS c SET p.typeCode = 'B_BUS'
FOR p WITHIN c.phones WHEN c.type='com.model' AND
p.typeCode != 'B_BUS' END LIMIT 1
我也尝试过这个也没有做任何事情,认为父类型可能不可用:
UPDATE `NoSQLDB` AS c SET p.typeCode = 'B_BUS'
FOR p WITHIN c.phones WHEN p.type='com.model.Phone' AND
p.typeCode != 'B_BUS' END LIMIT 1
如果有任何相关性,父 JSON 如下所示:
[
{
"NoSQLDB": {
"id": "01234",
"keyType": "BANANA",
"phones": [
{
"type": "com.model.Phone",
"typeCode": "H_HOME",
},
{
"type": "com.model.Phone",
"typeCode": "B_BUS",
}
],
"type": "com.model",
"updatedTimestamp": "2021-03-24T17:53:52.997+0000"
}
}
]
非常感谢任何关于我误入歧途的见解;先感谢您!
解决方案
全部 - 感谢任何正在审查的人,但我的一位团队成员发现了......如果有人遇到这个问题,请查看有效的更新查询:
UPDATE `NoSQLDB` AS c
SET p.typeCode = “B_BUS” FOR p IN phones WHEN p.typeCode != ‘B_BUS’ END
WHERE c.type=‘com.model’
推荐阅读
- flutter - How to show list of only the completed items?
- javascript - NodeJS 从另一个窗口获取像素颜色
- instagram - 如何从 instagram 嵌入帖子中获取个人资料图片 URL?
- java - 运行最新的 Jetty 版本会破坏我的构建
- mongodb - Docker 构建失败并显示“包 'mongodb' 没有安装候选者”
- javascript - 无论如何设置一个变量等于每次访问变量时调用的函数
- node.js - 为什么我收到的 jwt 格式错误?
- android - 如何从另一个类访问字符串变量?
- python - 使用 self 设置类变量值。与类名
- php - COUNT(*) 最大函数嵌套级别