- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
具有以下结构的文档:
{
path: String,
enabled: Long,
disabled: null || Long,
// other fields...
}
我想通过路径前缀和一些数字与文档时间戳之间的数字关系的组合来查找文档:(伪代码)
SELECT e FROM entries
WHERE
e.path STARTS WITH "somePrefix"
AND e.enabled <= timestamp
AND (
e.disabled == null
OR timestamp < e.disabled
)
我将从哪种索引结构中获益最多(如果有)?我是否应该在 enabled
字段上有一个非稀疏 skiplist 索引 + 在 disabled
上有一个稀疏索引,在 path
上有一个全文非稀疏索引? ArangoDB 是否能够为这些类型的查询使用多个索引?我阅读了关于索引使用的文档页面,但我仍然不清楚。
最佳答案
ArangoDB可以在同一个集合上使用多个索引,如果过滤条件用逻辑或组合,并且索引满足或分支条件。
对于您的查询,您有三个条件与逻辑和组合,后者包含一个或。
没有STARTS WITH
AQL 中的谓词,但您可以使用使用前缀边界构造的范围查询:e.path >= @lower && e.path < @upper
.对于 "somePrefix"
的搜索值,边界将转换为 @upper
正在"somePrefix", and
@低being
“somePrefiy”`(最后一个字符的搜索值增加一个)。
在 path
上创建跳过列表索引将使查询使用该索引。
包括 enabled
的搜索条件, 到现在的组合条件是e.path >= @lower && e.path < @upper && e.enabled <= @timestamp
.虽然可以在多个属性上创建跳过列表索引,但它不会在这两个属性上使用 path
和 enabled
, 但仅限于 path
.颠倒索引属性的顺序(即首先是 enabled
,然后是 path
)也无济于事,因为索引将用于 enabled
。只,但不在 path
.
一般情况下,skiplist 索引将用于条件中可以产生连续范围的部分。如果最左边的索引属性用于相等比较(例如 e.path == @path && e.enabled <= @timestamp
会起作用),但如果其最左边的索引属性是非相等比较(例如 e.path >= @lower && e.path <= @upper
或 @e.enabled <= @timestamp
),则它不会查看其进一步的索引属性,因为它无论如何都会产生一个不连续的范围。
还可以选择在 disabled
上创建跳过列表索引.这允许优化器在 e.enabled <= @timestamp && (e.disabled == null || @timestamp < e.disabled)
部分使用该索引.它可以将其转换为 e.disabled == null || @timestamp < e.disabled
, 然而看起来并不是很有选择性。
总而言之:似乎没有针对该特定查询的良好索引选择。如果你能以某种方式改变 STARTS WITH
进行相等比较,然后您可以在 path
上创建组合跳表索引和 enabled
,而且它可能会相当有选择性。如果你的STARTS WITH
前缀总是相同的大小,将前缀保存在一个额外的属性中可能是值得的,可以索引而不是原始值并使用相等比较查询:e.pathPrefix == @prefix && e.enabled <= @timestamp
.这需要为每个文档保存和维护一个额外的前缀属性,但在允许使用更具选择性的索引时,这可能是值得的。
关于arangodb - 关于 ArangoDB 中多索引的使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35587746/
我无法停止 arangodb docker 容器中的 arangodb 服务器。 当我执行低于一个时, $/etc/init.d/arangod 停止 $service arangodb 状态 ara
我在 java 中查询 ArangoDB 以获取数组值时遇到问题。我尝试过使用 String[] 和 ArrayList,都没有成功。 我的查询: FOR document IN documents
我想计算 ArangoDB 的服务器要求。 我知道 ArangoDB 将索引存储在 RAM 中,但是索引使用了多少空间? 最佳答案 这取决于您使用的索引类型。 您可以使用“数字”来查看需要多少内存:
我是 Arango DB 的新用户,目前正在为我的项目评估它。有人可以告诉我,您可以在 Arango DB 中创建的最大数据库数量是多少吗? 谢谢。 最佳答案 据我所知,ArangoDB 中的数据库数
我尝试从我的电脑连接到位于另一台服务器上的 ArangoDB,但似乎不成功。然后,我尝试使用输入服务器 ip http://x.x.x.x:8529 提供的 Web UI 来访问它。但也失败了。我在本
我有一个这样的文件: { "baths": 2, "beds": 3, "id": "3225C", "addrs": [ { "line2": "",
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
检索相关edge_collection中没有边的所有顶点的最佳方法是什么 我尝试使用以下代码,但自 arangodb 2.8 以来,它变得非常慢(在以前的版本中并不是很快,但比现在快了大约 10 倍)
我有许多节点通过其他类型的中间节点连接。如图所示,中间节点可以有多个。我需要找到给定数量的节点的所有中间节点,并按初始节点之间的链接数量对其进行排序。在我的示例中,给定 A、B、C、D,它应该返回节点
我有一个存储在 arangodb 中的对象,该对象具有其他内部对象,我当前的用例要求我仅更新其中一个元素。 存储对象 { "status": "Active", "physicalCode":
我正在尝试与 Arango 组合一个单元测试设置。为此,我需要能够在每次测试时重置测试数据库。 我知道我们可以直接从 REST API 删除数据库,但文档中提到创建和删除可能“需要一段时间”。 这是否
我有某种类型的事件列表,其结构如下: { createdAt: 123123132, type: STARTED, metadata: { emailAddress: "foo@bar
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 3 年前。
我发现使用 Web UI 在 arangodb 上创建新用户时遇到了麻烦。首先,我可以创建一个新用户,但无法为该用户分配一个数据库。另外,你能帮忙提供一个使用 arangodb Shell 的方法吗?
我在本地运行 ArangoDB,其中包含来自多个不同项目的数据库、集合、数据和图表。我想备份所有内容,以便重建我的系统。我知道如何备份单个数据库,但因为我有很多数据库,所以我希望一次性完成。 本质上,
应该很容易操作,但我找不到如何实现这一点。我有两个来自不同集合的文档,现在我想使用现有集合中的新 Edge 链接它们。我正在尝试像这样使用 edge-collection.save 函数:edge-c
在我解决 1000 个客户端的任务中,每个客户端都有单独的 ArangoDB,在运行时记录单独的信息......我们需要将这些信息聚合回单个主节点服务器中的集合,以便可以进行查询和报告在上面。研究 J
具有以下结构的文档: { path: String, enabled: Long, disabled: null || Long, // other fields... } 我想通过路
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 3 年前。
我想从 ArangoDB 的文档中删除一个属性。 我认为正确的方法是使用函数 UNSET(doc, attributeName1, ..., attributeNameN) .然而,仅凭这一点,数据库
我是一名优秀的程序员,十分优秀!