- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
众所周知,基于 Sparql 的存储或换句话说 TripleStore 的效率低于属性图存储,而且无法在保持属性图性能的同时进行分发。
我知道这里有很多事关紧要,例如推理等等。将分布和推理放在一边,我们可以将自己限制在可以通过 SPARQL 完全捕获的 RDFS,我想知道为什么会这样?
更具体地说,为什么存储是问题所在。是什么限制了基于 Sparql 的存储像 Property graph store 那样存储数据,并执行遍历而不是大量的连接查询。例如,sparql 不能简单地转换为 Gremlin 步骤吗?那里有什么限制?不能避免连接吗?
我的假设是,如果 sparql 可以在有效的步遍历中转换,并且数据存储为属性图,例如 janusGraph 做的 https://docs.janusgraph.org/latest/data-model.html ,那么性能问题将被桥接,同时保持一些推理,如 RDFS。
话虽这么说,Sparql 当然不是图灵完备的,但至少就它所做的而言,它可以快速完成,而且还可能是大规模的。在我看来,目标不是竞争,而是为了 SPARQL 的易用性和使用像 gremlin 这样的遍历语言来处理真正需要它的东西,例如联机处理程序。
是否有朝这个方向发展的项目,Apache jena 考虑过这些吗?
出于我上面解释的原因,我看到 Grakn 的 Graql 似乎正在使用这条路,因此是什么阻止了 TripleStore 社区?
最佳答案
@Michael,我很高兴你介入,因为你在这方面肯定比我更了解:)。在这一点上,我正在进行学习之旅。应您的要求,这里是启发我理解的论文之一:
arxiv.org/abs/1801.02911 (SPARQL querying of Property Graphs using Gremlin Traversals)
我引用他们
"We present a comprehensive empirical evaluation of Gremlinator and demonstrate its validity and applicability by executing SPARQL queries on top of the leading graph stores Neo4J, Sparksee and Apache TinkerGraph and compare the performance with the RDF stores Virtuoso, 4Store and JenaTDB. Our evaluation demonstrates the substantial performance gain obtained by the Gremlin counterparts of the SPARQL queries, especially for star-shaped and complex queries."
不过,他们解释说事情在某种程度上取决于查询的类型。
或者作为另一个答案把它放在堆栈溢出中 Comparison of Relational Databases and Graph Databases也有助于理解 Set 和 path 之间的问题。我的理解是 TripleStore 也适用于 Set。这就是说我绝对不知道最近在 TripleStore 中实现的所有优化技术,并且我看到了几篇解释技术以显着修剪集合连接操作的论文。
在分配上更多的是一种胆量感受。例如,以分布式方式进行连接操作对我来说听起来非常昂贵。我没有论文,我对这些问题的研究并不详尽。但是从我有红色的东西来看,我将不得不挖掘我的 Evernote :) 来支持它,这是分发的根本问题。此处的自动智能分片似乎无助于缓解该问题。
@Michael 这是一个非常复杂的主题。我肯定在旅途中,这就是为什么我正在帮助自己使用 stackoverflow 来指导我的研究。你可能知道为什么。因此,确实可以随意提供指针。
话虽这么说,但我并不是说 RDF 有问题,而 Property-Graph 更好。我是说,不知何故,当涉及到图形遍历时,有一些方法可以实现后端来加快速度。数据模型不是这里的问题,用于支持遍历的数据结构才是问题。我要说的第二件事是,查询语言的选择似乎会影响“遍历”的执行方式,从而影响用于支持数据模型的数据结构。
到目前为止,这是我的理解,是的,我确实知道还有很多其他因素在起作用,并且可以随意列举其中的一些来指导我的旅程。
简而言之,我的问题归结为,是否有可能让 RDF 存储由所谓的 native 图形存储支持,然后根据遍历步骤而不是根据其代数连接集合来实现 Sparql?这不会让事情变得更快一点吗?这似乎是 https://github.com/graknlabs/grakn 采取的方法。它主要由 janusGraph 支持,用于类似存储的图形。虽然它不是 RDF,但 Graql 与拥有 RDFS++ + Sparql 是相同的 Idea。他们声称只是做得更好,对此我有所保留,但这不是该线程的基本问题。最重要的是,他们通过信息检索(路径遍历)和 Property-Graph 倡导的伴随存储方法来支持知识表示。让我澄清一下,我并不是说图 native 存储是属性图的属性。在我看来,这是一种优化存储图结构的存储方法,其中信息检索涉及(路径)遍历:https://docs.janusgraph.org/latest/data-model.html .
关于sparql - 为什么 TripleStore 不像 Property-Graph Store 那样实现为 Native Graph Store?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53919402/
在这种情况下,我们在应用程序中同时使用react-native-gesture-handler Touchable和react-native Touchable。 (通过Touchables,我的意思
我有一个 MainFooter包含页脚和迷你播放器的组件,单击时动画显示为全 View 。我有一个问题,每当我们点击一个页脚选项卡时,播放器最大化然后卡在那里,没有响应。 此外,播放器内部的向下箭
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我在 native react 之上使用 native 基础组件,我想知道如何在 UI 中使卡片呈圆形而不是矩形。有圆形的 Prop 吗? 最佳答案 好吧,实际上没有人能回答这个问题,但幸运的是我在
我是 react-native 的新手,所以我认为“HTML”而不是“native”可能有点太多了,所以我的问题看起来很愚蠢。 我使用 react-native-router-flux 进行路由,并使
当我使用这个例子在我的应用程序上实现 Image-slider 时,我遇到了这个错误。 import React,{Component} from 'react' import {View,T
我正在为我们的产品使用“Native Base”组件,并且效果很好, 但我有一点被卡住了,它是关于将 Items 放入 Nativebase Picker 的问题。我的代码是这样的 渲染方法代码 -
正如文档中所建议的,我将一些长的数据获取代码移动到 native 模块中以释放 JS 线程,但我观察到这仍然阻塞了 UI。为什么会这样,我能做些什么来避免这种情况? 从 JS 调用 native 模块
我正在使用一个名为 react-native-svg 的框架在 React Native View 中绘制 SVG 元素。 我的目标是,当我点击 View 时(我在全局 View 上使用 PanRes
在 IOS 中发现错误 Native Module cannot be null 我不使用 react-native-push-notification 最佳答案 这通常发生在您未能将第三个库链接到您
当应用程序关闭时,我可以获得由 Linking.getInitialURL() 点击的深层链接网址。 .当应用程序处于后台状态时,则不会安装任何内容。所以,我什至无法通过 Linking.addEve
1) 说原生库是什么意思?什么样的图书馆?那些将用作 gradle 依赖项? 2)如何链接这些?我在使用 link 或 rnpm 时遇到了麻烦。 最佳答案 链接 native 库意味着您要将已经实现的
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我需要帮助来构建我的 react 原生项目。我尝试过react-native run-android,但出现以下错误: react-native : The term 'react-native' i
我是 React-Native 的新手,到目前为止我很喜欢它。我正在尝试创建一个屏幕(用于跨平台应用程序),右上角有一个菜单图标,单击时,我想打开一个菜单,希望使用 react-native-menu
RN doco 和其他示例展示了如何从 native iOS View Controller 启动 React-Native View ,但反之则不然。谁能解释一下我该怎么做? 最佳答案 我能够弄清楚
对于 react-native - WebStorm 用户: 我正在使用 Jet Brains IDE WebStorm 开始一个带有 React Native 的项目。 在项目 => node_mo
在升级过去的 react-native 0.60 之后......我被警告我应该取消链接所有手动链接的第 3 方库(因为 RN 现在通过自动链接处理它)。 但是,当我运行 react-native u
你可以使用像 https://github.com/tolu360/react-native-google-places 这样的库吗?在世博项目中?我假设任何 npm 库都可以添加,但是像这个 goo
我主要喜欢 React Native。自 0.22 以来一直在使用它。目前为 0.35。 但是为什么链接原生库就像抽奖一样呢?我很少在第一次拍摄时让它发挥作用,而破裂的东西通常是完全不同的东西。 每个
我是一名优秀的程序员,十分优秀!