0

我有一组 RDF 三元组,如下所示。

id#7289587  ex:getInfectedBy    id#7748320
id#7694711  ex:getInfectedBy    id#7748320
id#7748322  ex:getInfectedBy    id#7748320
id#7748887  ex:getInfectedBy    id#7748320

id#7746679  ex:getInfectedBy    id#7748510
id#6434108  ex:getInfectedBy    id#7748510
id#7458397  ex:getInfectedBy    id#7748510

我的目标是计算各种节点长度(4、5、6、...、20)的星形子图模式。例如,我编写了以下查询来查找节点长度为 4 (?s1 ?s2 ?s3 ?o) 的星形子图模式。

SELECT ?o count(distinct ?o)
WHERE
{
  ?s1 ?p ?o.
  ?s2 ?p ?o.
  ?s3 ?p ?o.FILTER((?s1!=?s2) && (?s1!=?s3) && (?s2!=?s3))
} group by ?o

上面提到的查询计算节点 4 的星型模式长度对于两个节点id#7748320id#7748510. 但是它假设只给我 node 的结果id#7748510。如果我用 5 节点星型模式修改查询,那么节点id#7748320也会出现在那里。你能帮我修一下吗?

是否可以通过一次查询计算各种节点长度(4,5,6,...,20)的星形子图模式?请告诉我。我感谢您的帮助。

4

1 回答 1

1

除了我的评论之外,我将简单地使用一个不同且更有效的查询“计算每个节点的所有传入节点”,然后使用以下方法对其进行过滤HAVING

SELECT  ?o (COUNT(DISTINCT ?s) AS ?cnt)
WHERE
  { ?s  ?p  ?node }
GROUP BY ?o
HAVING ( ?cnt = 3 ) # three incoming nodes
于 2017-05-04T12:57:01.783 回答