我使用 GraphDB 来存储不同的生产步骤。生产步骤以它们的步骤为代表,例如 A、B、C、D。属于一起的流程步骤由对象属性“:hasUpstreamProduktionsnummer”连接。
数据包含许多不同的工作流程。还缺少一些生产步骤。因此,工作流可以以 B 类的实例结束,也可以以 C 类的实例开始。
为了可视化工作流程,我需要创建一个表格,其中包含一行中的所有生产步骤,并为缺失的部分保留可用空间。例如:
A1 B1 C1
B2 C2
A3 B3
A4
C4
我的方法是 :hasUpstreamProduktionsnummer 作为 transtiv 和以下:
select distinct ?A ?B ?C where {
{ ?A a :A.
?A :hasUpstreamProduktionsnummer ?AUP.}
Optional
{ ?B owl:sameAs ?AUP.
?B a :B.}
Optional
{ ?C owl:sameAs ?AUP.
?C a :C. }
}
对于工作流 1,查询将产生以下结果:
A1 C1
A1 B1
A1
是否有任何选项可以在一行中查询它们?
有没有写查询效率更高的?就我而言,我需要为 B 和 C 写下相同的内容作为起点。
数据:
@base <http://BLB.de/Daten/Produktionsdaten/>
@prefix : <http://BLB.de/Daten/Produktionsdaten/> .
<A1> a :A;
:hasUpstreamProduktionsnummer <B1>.
<B1> a :B;
:hasUpstreamProduktionsnummer <C1>.
<C1> a :C.
<B2> a :B;
:hasUpstreamProduktionsnummer <C2>.
<C2> a :C.
<A3> a :A;
:hasUpstreamProduktionsnummer <B3>.
<B3> a :B.
<A4> a :A.
<C4> a :C
感谢您提前提供帮助!