sparql如何将子查询转换为另一个查询

Ani*_*vid 0 rdf semantic-web owl sparql

我有这些数据

@prefix : <http://test.example/> .

:alice :likes :beethoven.
:alice :likes :verdi.
:sofia :likes :beethoven.
:sofia :likes :verdi.
:sofia :likes :rossini.
:ania :likes :verdi.
:ania :likes :beethoven.
:ania :likes :david.
:david :likes :ania.
:david :likes :beethoven.
:david :likes :verdi.
:antonino :likes :verdi.
:antonino :likes :mozart.
:weirdo :likes :katyperry.
:beethoven a :recommendable.
:verdi a :recommendable.
:rossini a :recommendable.
:katyperry a :recommendable.
:mozart a :recommendable.
Run Code Online (Sandbox Code Playgroud)

然后我进行查询以获得喜欢与特定用户相同的项目的用户

select ?anotherUser (COUNT(?anotherItem) as ?countOfItems) WHERE {
  values ?user {:ania}
  ?anotherUser :likes ?anotherItem.
  filter (?anotherUser != ?user)
  filter exists {?user :likes ?anotherItem}
}group by ?anotherUser
order by desc(?countOfItems)
Run Code Online (Sandbox Code Playgroud)

现在我想获得这些用户喜欢的项目(但当然没有他们与特定用户共享的项目(:ania))

我知道我必须在另一个内部包含查询,我自己尝试了很多但没有成功,你能帮忙吗?

chr*_*ris 5

现在我想获得这些用户喜欢的项目(但当然没有他们与特定用户共享的项目(:ania))

我知道我必须在另一个内部包含查询,我自己尝试了很多但没有成功,你能帮忙吗?

我认为要记住的主要事情是最重要的是评估子查询,即查询从最里面的第一个到最外层进行评估.

所以以下查询:

prefix : <http://test.example>
select distinct ?user ?anotherUser ?item WHERE {
  ?anotherUser :likes ?item.
  filter not exists {?user :likes ?item}
  {select ?user ?anotherUser where {
    values ?user {:ania}
    ?anotherUser :likes ?anotherItem.
    filter (?anotherUser != ?user)
    filter exists {?user :likes ?anotherItem}
  }}
}
Run Code Online (Sandbox Code Playgroud)

会产生结果:

----------------------------------
| user  | anotherUser | item     |
==================================
| :ania | :sofia      | :rossini |
| :ania | :antonino   | :mozart  |
| :ania | :david      | :ania    |
----------------------------------
Run Code Online (Sandbox Code Playgroud)

这就是你要求的权利?