2016-08-05 5 views
0

내 쿼리는 이미지 목록에 대해 두 개의 sparql OPTIONS 절 중 어느 것이 먼저 오는지에 따라 결과를 반환합니다. 이 시점에서 Jena ARQ를 사용할 수있는 옵션은 없지만 순수 SPARQL 쿼리로이 문제를 해결하고 싶습니다. 그래도 Jena로 해결할 수있는 방법을 알고 싶습니다. 내 데이터 프레젠테이션은 아래에 첨부되어 있습니다. 데이터에는 이미지 목록이 포함될 수 있습니다. 내 이미지 표현도 아래에 있습니다. 내 쿼리도 첨부하고 있습니다. sprql 쿼리에는 이미지 목록이있는 경우 2 OPTIONS 블록에 선언 된 두 개의 변수 urlX 및 urlY가 있습니다. OPTIONS 중 어느 것이 먼저 오는지에 따라, 나는 하나의 변수에 대한 값을 얻고, 다른 하나에는 도달하지 못한다. 문제는 OPTIONS 절을 사용하는 것과 관련이있는 것 같습니다. 나는 그 대신에 내가 시도 할 수있는 것이 무엇인지 모르겠다. 나는 sparql 쿼리에 대한 전문가가 아니다. 나는 쿼리가 다음을 수행하기를 원한다. 이미지 콜렉션이 존재한다면, 두 이미지 크기 (dc : conformsTo)가 존재하는지보고 싶고, urlX와 urlY 값을 모두 얻거나 존재하는 것을 얻고 싶다. 많은 시간을 주셔서 감사합니다. sparql 쿼리 : 목록에서 여러 값 가져 오기

내 데이터 표현 :

@prefix dc: <http://purl.org/dc/terms/> . 
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> . 
@prefix lews: <http://lews.com/content/> . 
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> . 

lews:26331340 lews:name "the Human Good Luck Charm is Back"^^xsd:token ; 
     dc:created "2014-10-20T17:14:55.357-07:00"^^xsd:dateTime ; 
     dc:identifier "26331340"^^xsd:int ; 
     dc:modified "2016-08-04T13:43:00.897-07:00"^^xsd:dateTime ; 
     dc:title "the Human Good Luck Charm is Back" ; 
     dc:hasPart <http://lews.com/content/26331340#Images> ; 
     dc:abstract "As the World Series gets underway..." ; 
     dc:description "The super fan who rooted for the Royals is back to boost morale." ; 
     dc:subject "hoping for a World Series victory". 

<http://lews.com/content/26331340#Images> dc:identifier "Images"^^xsd:token ; 
     rdf:first lews:26331375 ; 
     rdf:rest _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331376 ; 
     rdf:li <http://lews.com/content/26331340#Images> , _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331376 , _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331377 , _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331378 , _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331379 , _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331380 ; 
     a rdf:List . 

_:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331376 rdf:first lews:26331376 ; 
     rdf:rest _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331377 . 

_:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331377 rdf:first lews:26331377 ; 
     rdf:rest _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331378 . 

_:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331378 rdf:first lews:26331378 ; 
     rdf:rest _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331379 . 

_:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331379 rdf:first lews:26331379 ; 
     rdf:rest _:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331380 . 

_:genid-15e530b0195547d9ac3f8e5e6785a747-x26331340Images26331380 rdf:first lews:26331380 ; 
     rdf:rest rdf:nil . 

내 이미지 표현 :

@prefix dc: <http://purl.org/dc/terms/> . 
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> . 
@prefix lews: <http://abcnews.com/content/> . 
@prefix mrss: <http://search.yahoo.com/mrss/> . 

@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> . 

lews:26331376 lews:name "141020_wn_donvan0_704x396.jpg"^^xsd:token ; 
     lews:section "wnt"^^xsd:token ; 
     lews:type "Image"^^xsd:token ; 
     dc:conformsTo "704x396"^^xsd:token ; 
     dc:created "2014-10-20T17:15:09.637-07:00"^^xsd:dateTime ; 
     dc:hasFormat <http://lews.go.com/images/WNT/141020_wn_donvan0_704x396.jpg> ; 
     dc:identifier "26331376"^^xsd:int ; 
     dc:isPartOf <http://lews.go.com/WNT> ; 
     dc:modified "2014-10-20T17:15:09.947-07:00"^^xsd:dateTime ; 
     dc:type "StillImage"^^xsd:token ; 
     mrss:height "396"^^xsd:int ; 
     mrss:width "704"^^xsd:int ; 
     xsd:date "2014-10-20"^^xsd:date ; 
     xsd:gMonthDay "--10-20"^^xsd:gMonthDay ; 
     xsd:gYear "2014"^^xsd:gYear ; 
     xsd:gYearMonth "2014-10"^^xsd:gYearMonth . 

내 쿼리 :

PREFIX dc:  <http://purl.org/dc/terms/> 
PREFIX mrss: <http://search.yahoo.com/mrss/> 
PREFIX search: <http://www.openrdf.org/contrib/lucenesail#> 
PREFIX xsd: <http://www.w3.org/2001/XMLSchema#> 
PREFIX lews: <http://abcnews.com/content/> 
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> 

SELECT ?id ?title ?description ?urlX ?urlY ?section ?imgName 
    ?subject dc:identifier ?id. 

    OPTIONAL {?subject dc:title ?title.} 
    OPTIONAL {?subject dc:description ?description.} 
    OPTIONAL {?subject dc:isPartOf ?section.} 

    OPTIONAL { 
       ?subject dc:hasPart ?imageCol. 
       ?imageCol dc:identifier "Images"^^xsd:token. 

       OPTIONAL{ 
        ?imageCol rdf:li ?bnode. 
        ?bnode rdf:first ?image. 
        ?image lews:name ?imgName;        
          dc:conformsTo "4x3"; 
          dc:hasFormat ?urlX.         
       }   
       OPTIONAL{ 
        ?imageCol rdf:li ?bnode. 
        ?bnode rdf:first ?image. 
        ?image lews:name ?imgName;        
          dc:conformsTo "16x9"; 
          dc:hasFormat ?urlY.         
       }   

    } 

} 
LIMIT ${limit} 
+1

데이터 항목별로 집계 및 그룹화를 사용하고 '샘플'을 사용하여 이미지 샘플을 선택할 수 있습니다. 하지만 처음에는 예를 들어 설명 된 것처럼 재미있는 SPARQL 1.1 속성 경로를 사용하여 하위 선택 목록을 해결해야한다고 생각합니다. 여기에 : http://stackoverflow.com/questions/17523804/is-it-possible-to-get-the-position-of-an-element-in-an-rdf-collection-in-sparql – AKSW

+0

나는 훑어 보았다. 집단적으로 볼 때 데이터가 어떻게 작동 하는지를 알 수는 없습니다. – user2917629

답변

1

내가 당신이 원하는 무엇인지 제대로 이해하면, 당신은 단지 필요 선택 사항을 다르게 그룹화하십시오 :

PREFIX dc:  <http://purl.org/dc/terms/> 
PREFIX mrss: <http://search.yahoo.com/mrss/> 
PREFIX search: <http://www.openrdf.org/contrib/lucenesail#> 
PREFIX xsd: <http://www.w3.org/2001/XMLSchema#> 
PREFIX lews: <http://abcnews.com/content/> 
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> 

SELECT ?id ?title ?description ?urlX ?urlY ?section ?imgName { 
    ?subject dc:identifier ?id. 

    OPTIONAL { ?subject dc:title ?title. } 
    OPTIONAL { ?subject dc:description ?description. } 
    OPTIONAL { ?subject dc:isPartOf ?section. } 

    OPTIONAL { 
     ?subject dc:hasPart ?imageCol. 
     ?imageCol dc:identifier "Images"^^xsd:token. 

     OPTIONAL { 
      ?imageCol rdf:li ?bnode. 
      ?bnode rdf:first ?image. 
      ?image lews:name ?imgName; 
      # Here we optionally bind ?urlX and/or ?urlY 
      OPTIONAL { 
       ?image dc:conformsTo "4x3"; 
        dc:hasFormat ?urlX. 
      } 
      OPTIONAL { 
       ?image dc:conformsTo "16x9"; 
        dc:hasFormat ?urlY. 
      } 
     } 
    } 
} 
관련 문제