3

私はSPARQLの初心者なので、助けていただければ幸いです。. 次のような RDF ドキュメントがあります。

  @prefix foaf: <http://xmlns.com/foaf/0.1/> .
  @prefix lb:   <http://example.org/lastfm/> .

  lb:bob     foaf:knows      lb:user2, lb:user3, lb:user4 ;
       foaf:age        25 ;
       lb:listenedTo   lb:track1, lb:track2 ;
       lb:topArtist    lb:artist1, lb:artist2 .        

  lb:user2   foaf:knows      lb:user5, lb:user6 ;
       foaf:age        40 ;
       lb:listenedTo   lb:track1, lb:track2, lb:track3 ;  
       lb:topArtist    lb:artist2, lb:artist4 .        

  lb:user3   foaf:knows      lb:user5, lb:bob, lb:user6 ;
       foaf:age        19 ;
       lb:listenedTo   lb:track2, lb:track3, lb:track4 ;
       lb:topArtist    lb:artist2, lb:artist3 .      

  lb:user4   lb:listenedTo   lb:track2, lb:track3, lb:track4 ;
       foaf:age        61 ;
       lb:topArtist    lb:artist3, lb:artist4, lb:artist5 .     

  lb:user5   foaf:knows      lb:user7 ;
       foaf:age        23 ;
       lb:topArtist    lb:artist1, lb:artist3 .

lb:bob最大で 3 回フォローしfoaf:knowsて、少なくとも 2 つのトラックを聴いたことのあるすべてのユーザーを見つけたいと考えています。次のようなクエリを書きました。

  PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
  prefix foaf: <http://xmlns.com/foaf/0.1/>
  prefix lb:   <http://example.org/lastfm/>

  select ?user
  where
  {
   lb:bob foaf:knows | foaf:knows/foaf:knows| foaf:knows/foaf:knows/foaf:knows ?user.
    ?user lb:listenedTo ?tracks
     minus{lb:bob lb:listenedTo ?track}
      filter (?tracks count(*)>=2)
  }

しかし、このエラー:

Encountered " "count" "count "" at line 12, column 23. Was expecting one of:
 "not" ...
 "in" ...
 <INTEGER_POSITIVE> ...
 <DECIMAL_POSITIVE> ...
 <DOUBLE_POSITIVE> ...
 <INTEGER_NEGATIVE> ...
 <DECIMAL_NEGATIVE> ...
 <DOUBLE_NEGATIVE> ...
 ")" ...
 "=" ...
 "!=" ...
 ">" ...
 "<" ...
 "<=" ...
 ">=" ...
 "||" ...
 "&&" ...
 "+" ...
 "-" ...
 "*" ...
 "/" ...

私のクエリには多くの問題があることを知っています。書き直してもらえますか?

4

1 に答える 1

5

どうですか:

prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
prefix foaf: <http://xmlns.com/foaf/0.1/>
prefix lb:   <http://example.org/lastfm/>

select ?user
where
{
  lb:bob foaf:knows | foaf:knows/foaf:knows| foaf:knows/foaf:knows/foaf:knows ?user.
  ?user lb:listenedTo ?tracks
}
group by ?user
having (count(?tracks) > 2)

あなたはminus私がよくわからない元のクエリにあります。おそらくlb:bob、のバインディングとして削除しようとしていますか? それを止めるでしょう。?userfilter (?user != lb:bob)

于 2013-07-11T13:55:49.047 に答える