Использование AllegroGraph 6.4.6
Я пытаюсь сгенерировать один запрос SPARQL DELETE с определением четырехугольников:
// Example of dataset used for generation of SPARQL
const quads = [
['<1>','<2>','<3>'], // Graph: DEFAULT
['<a>','<b>','<c>','<d>'], // Graph: <d>
['<w>','<x>','<y>','<z>'], // Graph: <z>
]
/* Example of triples being queried against
S P O G
--- --- --- ---
<1> <2> <3>
<a> <b> <c> <d>
<w> <x> <y> <z> If we delete <1> <2> <3>, we don't
<1> <2> <3> <4> <-- want to accidentally delete this quad
*/
IЯ могу сгенерировать запрос SELECT для определения существования всех квадов:
# Returns all specified quads that exist
SELECT ?s ?p ?o ?g
FROM DEFAULT
FROM NAMED <d>
FROM NAMED <z>
WHERE {
{
?s ?p ?o.
VALUES (?s ?p ?o) {
( <1> <2> <3> )
}
}
UNION
{
GRAPH ?g {?s ?p ?o.}
VALUES (?s ?p ?o ?g) {
( <a> <b> <c> <d> )
( <w> <x> <y> <z> )
}
}
}
- Возвращает все квады, указанные в
VALUES
<1> <2> <3> <4>
, не возвращается.
Следующий запрос является попыткой создания запроса DELETE, но имеет несколько проблем (обратите внимание на комментарии Option 1 и Option 2 ):
# Should delete all quads specified in VALUES
DELETE {
GRAPH ?g {?s ?p ?o.}
?sD ?pD ?oD.
}
# USING DEFAULT # Option 1
# USING NAMED <d> # Option 2
# USING NAMED <z> # Option 2
WHERE {
{
?sD ?pD ?oD.
VALUES (?sD ?pD ?oD) {
( <1> <2> <3> )
}
}
UNION
{
GRAPH ?g {?s ?p ?o.}
VALUES (?s ?p ?o ?g) {
( <a> <b> <c> <d> )
( <w> <x> <y> <z> )
}
}
}
С ONLY Опция 1 без комментариев, возвращается сообщение об ошибке:
Found DEFAULT. Was expecting one of: NAMED, Q_IRI_REF, QNAME, QNAME_NS.
Если только опция 2 не закомментирована, удаляются только указанные тройки именованных графов:
DELETED:
S P O G
--- --- --- ---
<a> <b> <c> <d>
<w> <x> <y> <z>
с ОБА опция 1 и Вариант 2 прокомментирован, каждая тройка удаляется, даже тройка <1> <2> <3> <4>
, которую мы не пытались удалить.
DELETED:
S P O G
--- --- --- ---
<1> <2> <3>
<a> <b> <c> <d>
<w> <x> <y> <z>
<1> <2> <3> <4>