我正在使用CosmosDB(通过documentdb api的node.js) - 仅在'id'上进行分区。
一个简单的查询(SELECT * FROM c WHERE c.akunaCustomer = "xyz"
)可以在Azure Query Explorer中正常工作,但我的node.js代码会出现以下错误 - 运行相同的查询。
code: 400, BadRequest, Cross partition query is required but disabled. Please set x-ms-documentdb-query-enablecrosspartition to true, specify x-ms-documentdb-partitionkey, or revise your query to avoid this exception.
这是我的代码:
var documentClient = require("documentdb").DocumentClient;
var config = require("./config");
var client = new documentClient(config.endpoint, {"masterKey": config.primaryKey});
var databaseUrl = `dbs/${config.database.id}`;
var collectionUrl = `${databaseUrl}/colls/${config.collection.id}`;
client.queryDocuments(collectionUrl,
'SELECT * FROM c WHERE c.akunaCustomer = "xyz"'
).toArray((err, results) => {
if(err) {
console.log(err);
}
else {
for (var queryResult of results) {
let resultString = JSON.stringify(queryResult);
console.log(`Query: ${resultString}`);
}
}
});
显然我错过了一些东西。 :-(任何帮助将不胜感激。
答案 0 :(得分:7)
错误消息非常明确:因为您的查询跨越多个分区,您需要将enableCrossPartitionQuery
选项设置为true
:
client.queryDocuments(
collectionUrl,
'SELECT * FROM c WHERE c.akunaCustomer = "xyz"',
{ enableCrossPartitionQuery: true }
)