首页 > 解决方案 > Couchbase 使用 N1QL 编辑文档

问题描述

我的 Couchbase 中有这样的数据:

{
“mappings”: {
“/”: “Ana sayfa”
},
“platform”: “WEB”
}

我想像这样转换所有数据:

{
“/”: {“viewLabel”:“Ana Sayfa”}
“platform”: “WEB”
}

所以我想分享旧版本:

{
“_class”: “com.commencis.appconnect.adminpanel.data.entity.ScreenNamesMappingEntity”,
“id”: “whitelabel::WEB::screenNamesMapping”,
“mappings”: {
“/”: “Ana sayfa”,
}
}

我想创建具有上述 id 的新文档:

 ( “id”: “whitelabel::WEB::screenNamesMapping”) 

并删除旧的。

我想像这样创建和转换:

{
“_class”: “com.commencis.appconnect.adminpanel.data.entity.ScreenNamesMappingEntity”,
“id”: “whitelabel::WEB::screenNamesMapping”,
“mappings”: {
“/”: { “viewLabel”: “Ana sayfa” } ,
}

我需要写脚本。我想创建具有相关ID的新文档,然后删除旧文档,它可能是多重N1QL

我不应该更新旧数据,新数据应该有新密钥,我应该用旧密钥编辑新密钥并删除旧密钥。我需要这样做。

标签: couchbasen1qlspring-data-couchbase

解决方案


您可以通过覆盖当前文档来使用相同的文档 ID,但是这两个实体应该有两个存储库。

oldRepository.findById("myid").ifPresent(e -> {
 NewEntity ne = new NewEntity(e.id(), e.platform()...);
 newRepository.save(ne); });

推荐阅读