Как удалить пустой узел и связанные с ним тройки одним запросом sparql? - PullRequest
0 голосов
/ 19 сентября 2018

Пример данных:

@prefix skos: <http://www.w3.org/2004/02/skos/core#> .
@prefix xs: <http://www.w3.org/2001/XMLSchema#> .
@prefix p0: <http://www.mlacustom.com#> .
@prefix p2: <http://www.mla.com/term/> .
_:bnode7021016689601753065 p0:lastModifiedDateTime "2018-09-14T12:55:38"^^<xsd:dateTime> ;
                           p0:lastModifiedUser "admin"^^xs:string .
<http://www.mla.com/name/4204078359> p0:hasClassingFacet "http://www.mla.com/facet/RA"^^xs:string ;
                                     p0:type "Normal"^^xs:string ;
                                     p0:classification _:bnode3452184423513029143 ,
                                                       _:bnode6827572371999795686 ;
                                     p0:recordType "Name"^^xs:string ;
                                     p0:recordNumber "4204078359"^^xs:string ;
                                     p0:stdDescriptor "classification111111"^^xs:string ;
                                     p0:establishedBy "admin"^^xs:string ;
                                     skos:prefLabel "classification111111"^^xs:string ;
                                     p0:createdBy "admin"^^xs:string ;
                                     a skos:Concept ;
                                     p0:createdDate "2018-09-14T12:55:38"^^<xsd:dateTime> ;
                                     p0:establishedDate "2018-09-14T12:55:38"^^<xsd:dateTime> ;
                                     p0:hasRAsubFacet "http://www.mla.com/subfacet/classing-subject-authors"^^xs:string ;
                                     p0:lastModifiedDate "2018-09-14T12:55:38"^^<xsd:dateTime> ;
                                     p0:lastModifiedDetails _:bnode7021016689601753065 ;
                                     p0:isProblematic "N,N"^^xs:string ;
                                     p0:lastModifiedBy "admin"^^xs:string ;
                                     p0:status "established"^^xs:string .
_:bnode3452184423513029143 p0:literature p2:1513 ;
                           p0:timePeriod p2:1005 ;
                           p0:language p2:3199 .
_:bnode6827572371999795686 p0:literature p2:11307 ;
                           p0:timePeriod p2:1009 ;
                           p0:language p2:31 .

В приведенных выше данных я хочу удалить пустые узлы classification и связанные с ними данные, которые p0:literature, p0:timePeriod, p0:language

Ниже удаляется запрос sparqlпустой узел связал тройки, что является ожидаемым поведением.

PREFIX skos-mla: <http://www.mlacustom.com#>
PREFIX name: <http://www.mla.com/name/>

WITH <thesaurus-term>
DELETE {
  ?class ?p ?o .
}
INSERT {}
WHERE {
  name:4408003840 skos-mla:classification ?class .
  ?class ?p ?o .
}

Я имею в виду эти данные

_:bnode3452184423513029143 p0:literature p2:1513 ;
                           p0:timePeriod p2:1005 ;
                           p0:language p2:3199 .
_:bnode6827572371999795686 p0:literature p2:11307 ;
                           p0:timePeriod p2:1009 ;
                           p0:language p2:31 .

Но я также хочу удалить классификационные тройки с основным IRI.эти тройки:

<http://www.mla.com/name/4204078359> 
                     p0:classification _:bnode3452184423513029143 ,
                                       _:bnode6827572371999795686 ;

Я должен удалить тройки в одном sparql.

1 Ответ

0 голосов
/ 20 сентября 2018

Для приведенных выше примеров данных следующее обновление удалит тройки p0:classification вместе со всем обоими bNodes, связанными с ним:

PREFIX p0: <http://www.mlacustom.com#>

delete {
    <http://www.mla.com/name/4204078359> p0:classification ?bnode .
    ?bnode ?p ?o .
} where {
    <http://www.mla.com/name/4204078359> p0:classification ?bnode .
    ?bnode ?p ?o .
}
...