- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 cosmos-db 索引策略和隐式全扫描感到困惑。
我的最终目标是:
假设我有一张这样的 table :
{
"id": "transactions",
"indexingPolicy": {
"indexingMode": "consistent",
"automatic": true,
"includedPaths": [
{
"path": "/transactionId/?"
},
{
"path": "/createdOn/?"
}
],
"excludedPaths": [
{
"path": "/*"
},
{
"path": "/\"_etag\"/?"
}
]
},
"partitionKey": {
"paths": [
"/chargePointId"
],
"kind": "Hash"
}
}
我认为这意味着我有 2 个一致的索引(在 transactionId 和createdOn 列上)。 Azure 门户不允许我指定索引类型:它“接受”更改,但是当它重新加载页面时,所有更改都消失了。
现在,我在禁用全扫描的情况下对不存在的列执行查询,假设它将失败并出现错误:已使用针对从索引中排除的路径的过滤器指定无效查询。考虑在请求中添加允许扫描 header 。
。
但是,这并没有发生。它工作正常并在控制台中打印 00:00:00
。
var policy = new ConnectionPolicy()
{
ConnectionMode = ConnectionMode.Gateway
};
var client = new DocumentClient(host, key, policy);
var queryText = "select * from c where c.asdasdasd > '2'";
var query = client.CreateDocumentQuery(
UriFactory.CreateDocumentCollectionUri("transactions", "transactions"),
queryText,
new FeedOptions
{
PopulateQueryMetrics = true,
EnableScanInQuery = false,
EnableCrossPartitionQuery = true,
}
).AsDocumentQuery();
var result = await query.ExecuteNextAsync();
var metrics = result.QueryMetrics;
Console.WriteLine(metrics.Single().Value.QueryEngineTimes.IndexLookupTime);
(代码取自本指南 https://learn.microsoft.com/en-us/azure/cosmos-db/sql-api-query-metrics )
我正在谈论的表是最近创建的(〜几周前)。我在另一个很久以前创建的数据库帐户中还有一个表。如果我尝试在该表上执行相同的操作 - 它会像我预期的那样失败。
我没有发现帐户或表臂模板(从 Azure 门户导出)有任何差异。
为什么它在新表上没有失败?它是否仍然默默地索引内容,或者新表不再考虑 EnableScanInQuery
?
最佳答案
我来自 CosmosDB 工程团队。我们正在逐渐删除对 EnableScanInQuery 的支持,因为它并未针对每个可能的查询(例如 SELECT * from r)统一强制执行。此外,当 EnableScanInQuery 设置为 false 时,仍然允许部分扫描(即使查询中选择性最少的谓词之一满足大量文档并且可以从索引提供服务,我们也会接受该查询,即使它可以有效地扫描)。对于今年年初开始的新容器,支持正在逐渐取消。优化查询以避免扫描的推荐方法是检查查询执行指标以确定是否需要对索引策略进行任何优化。
这实际上意味着,无论 EnableScanInQuery 如何,查询都可能降级为自动扫描以提供结果,并且对于不支持此选项的容器,用户不会看到任何错误消息。
关于azure - EnableScan InQuiry 不再适用于新的 Cosmos DB 容器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58268656/
我最近更新了 ADT 插件,我的整个 Eclipse-Android 构建系统都停止工作了。从那以后,我尝试了我在互联网上可以找到的所有关于如何解决这个问题的方法。徒然。如果有人有确定的方法来解决此问
我已经知道有类似的话题,但对我来说没有任何帮助...... 这里是信息: 该应用程序始终在模拟器和设备上运行。我最近将该项目重命名为另一个名称。仍然工作得很好。今天我意识到它没有更改文件夹名称,然后它
在装有El Capitan的MacMini上,我无法再进行冲泡了。我收到以下错误: /usr/local/Library/Homebrew/config.rb:34:in `initialize':
是的,所以我不知道发生了什么。我一直在编写一个 AJAX 评论脚本,并且它可以工作,但它不再工作了。我从备份中恢复了它,以防万一我改变了任何东西,但没有运气。它转到表单的“操作”而不是 jQuery,
请原谅我的无能...我正在尝试在全局 var 阶段不再未定义后使用 Proxy 执行一些代码。这是我天真的尝试: ``` var stage = undefined let myObj; let st
我对 segues 了解不多,但我已经开始工作了..但突然间它不再工作了...... 我的代码似乎可以工作,但没有发生 segue: NSLog(@"login started"); if ([use
我已将以下重写规则添加到我的 web.config 中。它运行良好,阻止了所有提及的推荐垃圾邮件站点。然而,今天我突然注意到 social-buttons.com 突然出现在我的 Google Ana
在 C++ 中,可以在翻译单元中使用 static 关键字来影响符号(变量或函数声明)的可见性。 在 n3092 中,这已被弃用: Annex D.2 [depr.static] The use of
升级到 com.crashlytics.sdk.android:crashlytics:2.7.1@aar 后(从 2.6.8 开始),我无法再在 Firebase 应用中禁用 Crashlytics
您好,我遇到了一些障碍,我一直在为我的应用程序重新设计菜单导航。我设法做到了。但现在我的应用程序的一项功能已决定停止运行。 想法是你摇动你的手机,它会随机选择一张图片,与应用程序分开的代码工作正常,就
我有一行(容器)包含三个元素,我想水平显示它们之间的间距相等(并且行的左侧或右侧没有空格)。我正在使用带有 justify-content:space-between 的 flexbox。 这是在 F
直到最近,我才能够在 Windows 上使用 python 3.6.7 时安装 tensorflow 1.5.0 包。现在我不能,从下面的“来自版本”的消息来看,似乎根本没有可用的 tensorflo
不确定是否与最近的更新有关,但我突然无法在 Android Studio 编辑器中获得单行间距。如果我尝试将它更改为 1,它让我设置它,但当我按下“应用”时,它会迅速恢复为 1.5。用不同的字体试过,
我遵循了有关如何在 macOS 上安装 pip 的在线说明(例如 this、this 和 this)。 我看起来很简单,但它不适合我。 我的 python --version 是 2.7.10。 当我
Due to rounding errors, most floating-point numbers end up being slightly imprecise. https://www.flo
我试图让用户从他们在 Android 上的库中选择一张图片。但是当我使用 PictureChooser 插件时,它似乎不再起作用了 我看到这段代码可以工作,但现在不行了,我也不知道为什么。
自 .NET 4.5 起,Exception.HResult 的 setter/getter 现在是 public,但它曾经是 protected。 来自 MSDN: Starting with th
今天去处理一个较旧的 Python2.7 AppEngine 标准项目,但我似乎无法让端点工作。我下载了示例代码,看看我的项目是否是罪魁祸首,但该示例也不起作用。 https://cloud.goog
我是一名优秀的程序员,十分优秀!