Wikidata:SPARQL query service/Query Helper
.
Query Helper allows you to create or modify an existing query without knowing SPARQL.
When working with the tool it will modify the SPARQL query, based on the input you provide in the visual interface, and vice versa.
Depending on last use, if it is not already displayed on the left side of the query editor, open the Query Helper by clicking on the corresponding icon of the tool sidebar.
What are the limitations?
editThis is an experimental tool and may break your SPARQL query.
- JSON serialization should not contain new lines.
- Template can be placed anywhere in the query: at the top, at the bottom for example.
- The content of the template will be added to the URL of the query. Some issues may occurs for that reason.
How to create a Query?
editThis section will show how you can create a query from scratch with the Query Helper.
In this example we will query all instances of zoo that are keeping a polar bear and a lion.
You can use identifiers Pxxx or Qxxx directly in the interface input fields to access the items correctly.
Add 'instance of zoo', 'species kept polar bear' and 'species kept lion' filter
edit- Click on 'Filter'
- Click on the combo box and enter 'zoo'
- Select the 'zoo (Q43501)' item from the combo box
- Click on 'Filter' and select 'polar bear (Q33609)'
- Click on 'Filter' and select 'lion (Q140)'
Add 'official website', 'image', 'coordinate location', 'inception' and 'species kept' columns
edit- Click on 'Show' and select 'official website (P856)'
- Click on 'Show' and select 'image (P18)'
- Click on 'Show' and select 'coordinate location (P625)'
- Click on 'Show' and select 'inception (P571)'
- Click on 'Show' and select 'species kept (P1990)'
Check your source |
---|
SELECT ?zoo ?official_website ?image ?coordinate_location ?inception ?species_kept ?species_keptLabel WHERE {
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
?zoo wdt:P31 wd:Q43501;
wdt:P1990 wd:Q33609, wd:Q140.
OPTIONAL { ?zoo wdt:P856 ?official_website. }
OPTIONAL { ?zoo wdt:P18 ?image. }
OPTIONAL { ?zoo wdt:P625 ?coordinate_location. }
OPTIONAL { ?zoo wdt:P571 ?inception. }
OPTIONAL { ?zoo wdt:P1990 ?species_kept. }
}
LIMIT 200
|
How to modify a Query?
editThis section will show how you can edit a query with the Query Helper
Change 'cat' to 'zoo'
edit- Select the 'Cats Query' from the examples
- Click on 'cat' to modify the value
- Click on the combo box and enter 'zoo'
- Select the 'zoo (Q43501)' item from the combo box
The query will now find items that have 'instance of zoo' instead of 'instance of cat'
Add 'country Germany' filter
edit- Click on 'Filter' button
- Enter 'Germany'
- Select 'Germany (Q183)'
- Click on 'instance of' from 'instance of Germany' to modify the value
- Click on the select box and enter 'Country'
- Select country (P17) item
The query will now only find items that have 'instance of zoo' and 'country Germany'
Add 'inception' and 'image' columns
edit- Click on 'Show' button
- Enter 'inception'
- Select 'inception (P571)' item
- Click on 'Show' button
- Enter 'image'
- Select 'image (P18)'
The query result now has two additional columns 'image' and 'inception' and can be displayed as a Timeline or Image Grid.
Add a title
editIn the code view, in the right-hand pane, add #title: Your title
at the beginning of the query; changing "Your title" to whatever you would like the title to be.
Query Templates
editUse a Query Template
editQueries that have a Query Template defined will show the defined textual representation of this query inside of the Query Helper.Query Helper allows you to create or modify an existing query without knowing SPARQL.
When working with the tool it will modify the SPARQL query, based on the input you provide in the visual interface, and vice versa.
It is displayed on the left side of the query editor.
Blue items in this textual representation can be clicked to modify them.
Defined suggestions will be shown or a text can be entered to search for a replacement.
When selecting one of the items in the list it will replace the item in the textual representation and the SPARQL query.
You can find all the queries in the Query Examples List that have a defined Query Template by searching for '#TEMPLATE' in the page text.
Create a Query Template
editQuery templates can be created by providing a template definition. Here is an example query with a template definition.
The definition is expressed in JSON and inserted as SPARQL comment to the query like this:
#TEMPLATE=[JSON_DEFINITION]
JSON definition example:
{
"template": "Largest ?c with ?sex head of government",
"variables": {
"?sex": {},
"?c": {
"query": "SELECT DISTINCT ?id WHERE { ?c wdt:P31 ?id. ?c p:P6 ?mayor. }"
}
}
}
Key | Value | Example | Description | SPARQL Query |
---|---|---|---|---|
template | This text will be shown to the user as description for the query.
In the text you can define variables that will be replaced by actual values. |
Largest ?c with ?sex head of government | This will define two variables within the text:
?c and ?sex The values for this variables must be defined in the SPARQL query. |
BIND(wd:Q6581072 AS ?sex)
BIND(wd:Q515 AS ?c)
|
variables | In this section you have to define the variables from the template.
You can optionally define a SPARQL query that is used for suggesting values for that variable. |
"?sex": {},
"?c": {
"query": "[SPARQL]"
}
|
This will define two variables:
?c and ?sex For the variable ?c there is a SPARQL query defined that will suggest Items. |
SELECT DISTINCT ?id WHERE
{ ?c wdt:P31 ?id.?c p:P6 ?mayor. }
SELECT ?id ?label ?description WITH {
[QUERY]
} AS %inner
WHERE {
INCLUDE %inner
?id rdfs:label ?label.
?id schema:description ?description.
FILTER((LANG(?label)) = "en")
FILTER((LANG(?description)) = "en") }
ORDER BY DESC(?count)
LIMIT 20
|