嗨,我是 MongoDB 和 CosmosDB 的新手,我尝试在 C# 中实现这一点
MongoClientSettings settings = MongoClientSettings.FromUrl(
new MongoUrl(connectionString)
);
settings.SslSettings =
new SslSettings() { EnabledSslProtocols = SslProtocols.Tls12 };
var mongoClient = new MongoClient(settings);
var mongoDatabase = mongoClient.GetDatabase("MYDATABASE");
var mongoCollection = mongoDatabase.GetCollection<BsonDocument>("MYCOLLECTION");
var builder = Builders<BsonDocument>.Filter;
var filter = builder.Lt("mac", "001BC50670101BB8") & builder.Gte("date", "2016-09-18T00:00:00Z") & builder.Gte("date", "2017-09-22T00:00:00Z");
var query = mongoCollection.Find<BsonDocument>(filter).ToList<BsonDocument>();
但是当它在服务器上运行查询时,我收到此错误:
Errors":["An invalid query has been specified with filters against path(s) that are not range-indexed. Consider adding allow scan header in the request."
我发现我应该将“x-ms-documentdb-query-enable-scan” header 添加到我的请求中。但我怎样才能做到这一点呢?
最佳答案
评论部分找到的解决方案:
查询更改自
builder.Lt("mac", "001BC50670101BB8")
到
builder.Eq("mac", "001BC50670101BB8")
关于c# - 带有 MongoDB API 的 CosmosDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46338553/