Couchbase 如何以特定格式获取n1ql查询响应?

Couchbase 如何以特定格式获取n1ql查询响应?,couchbase,n1ql,Couchbase,N1ql,当我执行下面的查询时 SELECT r.name AS organizationRoleName, r.organizationRoleId, a.city, a.zip,a.address1 FROM `contact` AS c UNNEST c.organizationRoles AS r UNNEST r.addressAssociations AS aa jOIN `optima_contact` AS a ON aa.addressId = TO_NUMBER(a.addressId

当我执行下面的查询时

SELECT r.name AS organizationRoleName, r.organizationRoleId, a.city, a.zip,a.address1
FROM `contact` AS c
UNNEST c.organizationRoles AS r
UNNEST r.addressAssociations AS aa
jOIN `optima_contact` AS a
ON aa.addressId = TO_NUMBER(a.addressId) 
WHERE  c.type = "organization" AND a.type = "address" and a.city="Plaridel";
我得到的答复如下

[
   {
 "address1": "Ground Floor Waltermart Center-Plaridel, Cagayan Valley Road, Barrio Banga 1, Plaridel",
"city": "Plaridel",
"organizationRoleId": 903,
"organizationRoleName": "SUN - WALTERMART PLARIDEL",
"zip": "3004"
},
{
"address1": "Ground Floor Waltermart Center-Plaridel Cagayan Valley Road Barrio Banga 1 Plaridel",
"city": "Plaridel",
"organizationRoleId": 1001,
"organizationRoleName": "FRS1 Store",
"zip": "3004"
  }
]
是否仍然需要以下面的格式而不是上面的格式获取响应

[
{
"organizationRoleId": 903,
"organizationRoleName": "SUN - WALTERMART PLARIDEL",
"storeAddress": {
                "address1": "Ground Floor Waltermart Center-Plaridel, Cagayan Valley Road, Barrio Banga 1, Plaridel",
                "city": "Plaridel",
                "zipCode": "3004"
            }
},
{
"organizationRoleId": 1001,
"organizationRoleName": "FRS1 Store",
"storeAddress": {
                "address1": "Ground Floor Waltermart Center-Plaridel Cagayan Valley Road Barri Banga 
                             1 Plaridel",
                "city": "Plaridel",
                "zipCode": "3004"
            }
  }
  ]

获取上述类型响应的方法应该是什么?

您可以使用{city,zip,address1}和别名作为storeAddress来构造对象

SELECT r.name AS organizationRoleName, r.organizationRoleId,
       {a.city, a.zip,a.address1} AS storeAddress
FROM `contact` AS c
UNNEST c.organizationRoles AS r
UNNEST r.addressAssociations AS aa
jOIN `optima_contact` AS a
ON aa.addressId = TO_NUMBER(a.addressId) 
WHERE  c.type = "organization" AND a.type = "address" and a.city="Plaridel";

您可以使用{city,zip,address1}和别名作为storeAddress来构造对象

SELECT r.name AS organizationRoleName, r.organizationRoleId,
       {a.city, a.zip,a.address1} AS storeAddress
FROM `contact` AS c
UNNEST c.organizationRoles AS r
UNNEST r.addressAssociations AS aa
jOIN `optima_contact` AS a
ON aa.addressId = TO_NUMBER(a.addressId) 
WHERE  c.type = "organization" AND a.type = "address" and a.city="Plaridel";