SPARQLSPARQL (graphenbasierte Abfragesprache für Abfragen von Inhalten aus dem Beschreibungssystem Resource Description Framework (RDF), die in Datenbanken zur Formulierung logischer Aussagen über beliebige Dinge genutzt wird. Der Name ist ein rekursives Akronym für SPARQL Protocol And RDF Query Language. ) ist eineDie RDF Data Access Working Group (DAWG) des World Wide Web Consortiums (W3C) trieb die Entwicklung und Standardisierung von SPARQL voran. Im April 2006 wurde SPARQL als Candidate Recommendation anerkannt, im Oktober 2006 ist es jedoch wieder zum Working Draft zurückgestuft worden. Seit Juni 2007 lag SPARQL erneut als Candidate Recommendation des W3C vor. Am 15. Januar 2008 wurde SPARQL endgültig vom W3C als Recommendation freigegeben.[1] Seit dem 21. März 2013 ist die W3C Recommendation für SPARQL 1.1 veröffentlicht worden.[2] SPARQL ist der Nachfolger mehrerer Abfragesprachen, z. B. RDF Query Language, RDQL, die ebenfalls auf RDF-Daten zugreifen. Der Wikidata Query Service ist eine Web Application, die einen SPARQL-Endpunkt mit einer Benutzeroberfläche zur Verfügung stellt.[3] Damit kann auf alle Datenobjekte zugegriffen werden, die in Wikidata gespeichert sind.[4][5] Dort sind viele SPARQL-Abfragen als Beispiele angegeben.[6] EigenschaftenDas Resource Description Framework (RDF) ist eine Modellierungssprache für beschriftete gerichtete Graphen zur Darstellung von Informationen im World Wide Web. Diese Spezifikation definiert die Syntax und Semantik der Abfragesprache SPARQL für RDF. SPARQL kann verwendet werden, um Abfragen über verschiedene Datenquellen hinweg auszudrücken, unabhängig davon, ob die Daten nativ als RDF gespeichert oder über Middleware als RDF angezeigt werden. SPARQL enthält Funktionen zum Abfragen erforderlicher und optionaler Graphenmuster sowie deren Und-Verknüpfungen (Konjunktion) und Oder-Verknüpfungen (Disjunktion). SPARQL unterstützt auch das Testen erweiterbarer Werte und das Einschränken von Abfragen. Die Ergebnisse von SPARQL-Abfragen können Ergebnismengen oder RDF-Diagramme sein.[7] BeispieleDie folgende Abfrage gibt alle in München geborenen Menschen zurück, die in der Datenbank gespeichert sind. SELECT ?human ?humanLabel ?humanDescription
WHERE
{
?human wdt:instanceOf wd:human;
wdt:placeOfBirth wd:Munich.
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en" }
}
Die Variable Die folgende Abfrage findet die Namen aller Hauptstädte in Europa und das Land, in dem sich die jeweilige Hauptstadt befindet und sortiert das Ergebnis alphabetisch nach Ländern. PREFIX abc: <http://example.com/exampleOntology#>
SELECT ?capital ?country
WHERE
{
?x abc:cityname ?capital;
abc:isCapitalOf ?y.
?y abc:countryname ?country;
abc:isInContinent abc:Europe.
}
ORDER BY ?country
Variablen werden mit vorangestelltem Weil das Ausschreiben der URIs die Lesbarkeit einer Abfrage mindert, können Präfixe verwendet werden. Hier steht ein „abc:“ für „http://example.com/exampleOntology#“ Die folgende Abfrage findet die Namen aller Regierungschefs, die Väter sind, und die Anzahl ihrer Kinder. Die Regierungschefs werden absteigend sortiert nach der Anzahl der Kinder ausgegeben. SELECT ?father ?fatherLabel (COUNT(*) AS ?children)
WHERE
{
?child wdt:isFather ?father.
?father wdt:instanceOf wd:human;
wdt:positionHeld wd:headOfGovernment.
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en" }
}
GROUP BY ?father ?fatherLabel
ORDER BY DESC(?children)
Das Ergebnis wird nach den Vätern (Regierungschefs) gruppiert. In der Variablen Anfrage-Engines
Literatur
Weblinks
Einzelnachweise
|