Virtuoso R2RML rr: создание IRI

У меня проблема с генерацией rr:termTyperr:IRI Виртуоз. Я не знаю, делаю ли я это неправильно, но я следовал спецификации W3C.

Мое отображение выглядит так. Когда я генерирую тройки с CONSTRUCT заявление, которое я до сих пор получаю "URL" но нет IRI => <url> (OWNER_LINK а также BRAND_LINK колонны). Virtuoso это не поддерживает или я пишу это неправильно?

DB.DBA.TTLP 
   (  '
        @prefix    rr:  <http://www.w3.org/ns/r2rml#>                                .
        @prefix  foaf:  <http://xmlns.com/foaf/0.1/>                                 .
        @prefix    gr:  <http://purl.org/goodrelations/v1#>                          .
        @prefix     s:  <http://schema.org/>                                         .
        @prefix   pod:  <http://linked.opendata.cz/ontology/product-open-data.org#>  .

        <#TriplesMap3>
           a                 rr:TriplesMap  ;
           rr:logicalTable 
              [
                 rr:tableSchema "POD"  ;
                 rr:tableOwner  "DBA"  ;
                 rr:tableName   "BRAND_OWNER_BSIN"
              ];
           rr:subjectMap 
              [ 
                 rr:template  "http://linked.opendata.cz/resource/brand-owner-bsin/{BSIN}"  ;
                 rr:class     gr:BusinessEntity                                             ;
                 rr:graph     <http://linked.opendata.cz/resource/dataset/product-open-data.org/2014-01-01>
              ];
        rr:predicateObjectMap 
              [
                 rr:predicate gr:hasBrand  ;
                 rr:objectMap 
                    [
                       rr:parentTriplesMap <#TriplesMap4>  ;
                       rr:joinCondition 
                          [
                             rr:child "OWNER_CD"   ;
                             rr:parent "OWNER_CD"  ;
              ];    ];    ];
        .


        <#TriplesMap4>
           a                rr:TriplesMap  ;
           rr:logicalTable 
              [
                 rr:tableSchema  "POD"          ;
                 rr:tableOwner   "DBA"          ;
                 rr:tableName    "BRAND_OWNER"
              ];
           rr:subjectMap 
              [ 
                 rr:template  "http://linked.opendata.cz/resource/brand-owner/{OWNER_CD}"  ;
                 rr:class     gr:BusinessEntity                                            ;
                 rr:graph     <http://linked.opendata.cz/resource/dataset/product-open-data.org/2014-01-01>
              ];

        rr:predicateObjectMap 
           [
              rr:predicate  gr:legalName  ;
              rr:objectMap
                 [ rr:column  "OWNER_NM" ];
           ];
        rr:predicateObjectMap 
           [
              rr:predicate  s:url  ;
              rr:objectMap
                 [
                    rr:termType  rr:IRI        ; 
                    rr:column    {OWNER_LINK}  ;
           ];    ];
        rr:predicateObjectMap 
           [
              rr:predicate  gr:hasBrand  ;
              rr:objectMap
                 [
                    rr:parentTriplesMap  <#TriplesMap3>  ;
                    rr:joinCondition 
                       [
                          rr:child   "OWNER_CD"   ;
                          rr:parent  "OWNER_CD"  ;
           ];   ];     ];
        .

        <#TriplesMap2>
           a                rr:TriplesMap;    
           rr:logicalTable 
              [
                 rr:tableSchema "POD"; 
                 rr:tableOwner  "DBA"; 
                 rr:tableName   "BRAND_TYPE" 
              ];
           rr:subjectMap 
              [ 
                 rr:template  "http://linked.opendata.cz/resource/brand-type/{BRAND_TYPE_CD}"  ;
                 rr:class     gr:BusinessEntityType                                            ;
                 rr:graph     <http://linked.opendata.cz/resource/dataset/product-open-data.org/2014-01-01>
              ];
           rr:predicateObjectMap 
              [
                 rr:predicate  gr:name  ;
                 rr:objectMap
                    [ rr:column  "BRAND_TYPE_NM" ];
              ];
        .


        <#TriplesMap1>
           a                rr:TriplesMap;    
           rr:logicalTable 
              [
                 rr:tableSchema "POD"   ; 
                 rr:tableOwner  "DBA"   ; 
                 rr:tableName   "BRAND" 
              ];
           rr:subjectMap 
              [ 
                 rr:template  "http://linked.opendata.cz/resource/brand/{BSIN}"  ;
                 rr:class     gr:Brand                                           ;
                 rr:graph     <http://linked.opendata.cz/resource/dataset/product-open-data.org/2014-01-01>
              ];
           rr:predicateObjectMap 
              [
                 rr:predicate  pod:bsin               ;
                 rr:objectMap  [ rr:column  "BSIN" ]  ;
              ];   
           rr:predicateObjectMap
              [
                 rr:predicate  gr:name                    ;
                 rr:objectMap  [ rr:column  "BRAND_NM" ]  ;
              ];
           rr:predicateObjectMap 
              [
                 rr:predicate  s:url  ;
                 rr:objectMap
                    [
                       rr:termType  rr:IRI        ; 
                       rr:column    "BRAND_LINK"  ;
              ];    ];

           rr:predicateObjectMap 
              [
                 rr:predicate  gr:BusinessEntityType  ;
                 rr:objectMap 
                    [
                       rr:parentTriplesMap  <#TriplesMap2>  ;
                       rr:joinCondition 
                          [
                             rr:child "BRAND_TYPE_CD"    ;
                             rr:parent "BRAND_TYPE_CD"   ;
              ];    ];    ];
        .
      ', 
      'http://product-open-data.org/temp', 
      'http://product-open-data.org/temp' 
   );

exec ( 'sparql ' || DB.DBA.R2RML_MAKE_QM_FROM_G ('http://product-open-data.org/temp') );

2 ответа

Решение

Итак, я понял, что мой код был неправильным, так должно быть

 rr:predicateObjectMap 
    [
       rr:predicateMap
          [
             rr:constant  s:url 
          ]; 
       rr:objectMap 
          [ 
             rr:termType  rr:IRI          ; 
             rr:template  "{BRAND_LINK}"  ;
          ];

     ];.

и это работает

Спасибо.

Чтобы было ясно - вы говорите, что отображение R2RML загружается успешно, но при запуске SPARQL CONSTRUCT запрос, rr:termType rr:IRI отображение не отображается в наборе результатов?

Как показывают документы, только rr:sqlQuery в настоящее время не поддерживается...

Другие вопросы по тегам