query-6c8d3d0365b518384c077abca7237b29

rq turtle/ttl

Au 4 août 1976, il y a 26 régions. SELECT DISTINCT ?inseeRégion ?région ?nom ?inseeCheflieu ?cheflieu WHERE { BIND ( "1976-08-04"^^xsd:dateTime as ?dateRecherche )

?région p:P2585 ?P2585node . # existence d'un code Insee ?P2585node ps:P2585 ?inseeRégion . # valeur du code Insee OPTIONAL { ?région wdt:P571 ?dateCréation . } # date de création OPTIONAL { ?région wdt:P576 ?dateDissolution . } # date de dissolution

?région p:P1448 ?P1448node . # existence d'un nom ?P1448node ps:P1448 ?nom . # valeur du nom FILTER( lang(?nom)="fr" ). # nom en français MINUS { ?P1448node pq:P3831 wd:Q96406455 . } # nom long MINUS { ?P1448node pq:P2241 ?dépréciationNom . } # nom erroné OPTIONAL { ?P1448node pq:P580 ?dateDébutNom . } # date de début du nom OPTIONAL { ?P1448node pq:P582 ?dateFinNom . } # date de fin du nom

?région p:P36 ?P36node . # existence d'un chef-lieu ?P36node ps:P36 ?cheflieu . # valeur du chef-lieu OPTIONAL { ?P36node pq:P580 ?dateDébutCheflieu . } # date de début du chef-lieu OPTIONAL { ?P36node pq:P582 ?dateFinCheflieu . } # date de fin du chef-lieu ?cheflieu p:P374 ?P374node . # existence d'un code Insee du chef-lieu ?P374node ps:P374 ?inseeCheflieu . # valeur du code Insee du chef-lieu OPTIONAL { ?P374node pq:P580 ?dateDébutCode . } # date de début du code Insee du chef-lieu OPTIONAL { ?P374node pq:P582 ?dateFinCode . } # date de fin du code Insee du chef-lieu

FILTER ( !BOUND(?dateCréation) || ?dateCréation <= ?dateRecherche ) # ancienne région
FILTER ( !BOUND(?dateDissolution) || ?dateDissolution > ?dateRecherche ) # future région 
FILTER ( !BOUND(?dateDébutCheflieu) || ?dateDébutCheflieu <= ?dateRecherche ) # ancien chef-lieu
FILTER ( !BOUND(?dateFinCheflieu) || ?dateFinCheflieu > ?dateRecherche ) # futur chef-lieu  
FILTER ( !BOUND(?dateDébutCode) || ?dateDébutCode <= ?dateRecherche ) # ancien code du chef-lieu
FILTER ( !BOUND(?dateFinCode) || ?dateFinCode > ?dateRecherche ) # futur code du chef-lieu 
FILTER ( !BOUND(?dateDébutNom) || ?dateDébutNom <= ?dateRecherche ) # ancien nom
FILTER ( !BOUND(?dateFinNom) || ?dateFinNom > ?dateRecherche ) # futur nom

} ORDER BY ?inseeRégion

Use at

PREFIX xsd: <http://www.w3.org/2001/XMLSchema#>
PREFIX wdt: <http://www.wikidata.org/prop/direct/>
PREFIX wd: <http://www.wikidata.org/entity/>
PREFIX ps: <http://www.wikidata.org/prop/statement/>
PREFIX pq: <http://www.wikidata.org/prop/qualifier/>
PREFIX p: <http://www.wikidata.org/prop/>
# Au 4 août 1976, il y a 26 régions.
SELECT DISTINCT ?inseeRégion ?région ?nom ?inseeCheflieu ?cheflieu WHERE {
  BIND ( "1976-08-04"^^xsd:date as ?dateRecherche ) 

   ?région p:P2585 ?P2585node . # existence d'un code Insee
    ?P2585node ps:P2585 ?inseeRégion . # valeur du code Insee
    OPTIONAL { ?région wdt:P571 ?dateCréation . } # date de création
    OPTIONAL { ?région wdt:P576 ?dateDissolution . } # date de dissolution

   ?région p:P1448 ?P1448node . # existence d'un nom
    ?P1448node ps:P1448 ?nom . # valeur du nom
    FILTER( lang(?nom)="fr" ). # nom en français
    MINUS { ?P1448node pq:P3831 wd:Q96406455 . } # nom long
    MINUS { ?P1448node pq:P2241 ?dépréciationNom . } # nom erroné
    OPTIONAL { ?P1448node pq:P580 ?dateDébutNom . } # date de début du nom
    OPTIONAL { ?P1448node pq:P582 ?dateFinNom . } # date de fin du nom 

   ?région p:P36 ?P36node . # existence d'un chef-lieu
    ?P36node ps:P36 ?cheflieu . # valeur du chef-lieu
    OPTIONAL { ?P36node pq:P580 ?dateDébutCheflieu . } # date de début du chef-lieu
    OPTIONAL { ?P36node pq:P582 ?dateFinCheflieu . } # date de fin du chef-lieu 
    ?cheflieu p:P374 ?P374node . # existence d'un code Insee du chef-lieu
    ?P374node ps:P374 ?inseeCheflieu . # valeur du code Insee du chef-lieu
    OPTIONAL { ?P374node pq:P580 ?dateDébutCode . } # date de début du code Insee du chef-lieu
    OPTIONAL { ?P374node pq:P582 ?dateFinCode . } # date de fin du code Insee  du chef-lieu

    FILTER ( !BOUND(?dateCréation) || ?dateCréation <= ?dateRecherche ) # ancienne région
    FILTER ( !BOUND(?dateDissolution) || ?dateDissolution > ?dateRecherche ) # future région 
    FILTER ( !BOUND(?dateDébutCheflieu) || ?dateDébutCheflieu <= ?dateRecherche ) # ancien chef-lieu
    FILTER ( !BOUND(?dateFinCheflieu) || ?dateFinCheflieu > ?dateRecherche ) # futur chef-lieu  
    FILTER ( !BOUND(?dateDébutCode) || ?dateDébutCode <= ?dateRecherche ) # ancien code du chef-lieu
    FILTER ( !BOUND(?dateFinCode) || ?dateFinCode > ?dateRecherche ) # futur code du chef-lieu 
    FILTER ( !BOUND(?dateDébutNom) || ?dateDébutNom <= ?dateRecherche ) # ancien nom
    FILTER ( !BOUND(?dateFinNom) || ?dateFinNom > ?dateRecherche ) # futur nom   
}
ORDER BY ?inseeRégion

Query found at

graph TD classDef projected fill:lightgreen; classDef literal fill:orange; classDef iri fill:yellow; v14("?P1448node") v13("?P2585node") v16("?P36node") v18("?P374node") v17("?cheflieu"):::projected v10("?dateCréation") v9("?dateDissolution") v8("?dateDébutCheflieu") v6("?dateDébutCode") v4("?dateDébutNom") v7("?dateFinCheflieu") v5("?dateFinCode") v2("?dateFinNom") v12("?dateRecherche") v15("?dépréciationNom") v19("?inseeCheflieu"):::projected v1("?inseeRégion"):::projected v11("?nom"):::projected v12("?région"):::projected c9(["wd:Q96406455"]):::iri f0[["(not bound(?dateFinNom) || ?dateFinNom > ?dateRecherche)"]] f0 --> v2 f0 --> v12 f1[["(not bound(?dateDébutNom) || ?dateDébutNom <= ?dateRecherche)"]] f1 --> v4 f1 --> v12 f2[["(not bound(?dateFinCode) || ?dateFinCode > ?dateRecherche)"]] f2 --> v5 f2 --> v12 f3[["(not bound(?dateDébutCode) || ?dateDébutCode <= ?dateRecherche)"]] f3 --> v6 f3 --> v12 f4[["(not bound(?dateFinCheflieu) || ?dateFinCheflieu > ?dateRecherche)"]] f4 --> v7 f4 --> v12 f5[["(not bound(?dateDébutCheflieu) || ?dateDébutCheflieu <= ?dateRecherche)"]] f5 --> v8 f5 --> v12 f6[["(not bound(?dateDissolution) || ?dateDissolution > ?dateRecherche)"]] f6 --> v9 f6 --> v12 f7[["(not bound(?dateCréation) || ?dateCréation <= ?dateRecherche)"]] f7 --> v10 f7 --> v12 f8[["?nom = 'fr'"]] f8 --> v11 bind9[/"'1976-08-04^^xsd:date'"/] bind9 --as--o v12 v12 --"p:P2585"--> v13 v13 --"p:statement/P2585"--> v1 subgraph optional0["(optional)"] style optional0 fill:#bbf,stroke-dasharray: 5 5; v12 -."p:direct/P571".-> v10 end subgraph optional1["(optional)"] style optional1 fill:#bbf,stroke-dasharray: 5 5; v12 -."p:direct/P576".-> v9 end v12 --"p:P1448"--> v14 v14 --"p:statement/P1448"--> v11 subgraph minus10["MINUS"] style minus10 stroke-width:6px,fill:pink,stroke:red; v14 --"p:qualifier/P3831"--> c9 end subgraph minus11["MINUS"] style minus11 stroke-width:6px,fill:pink,stroke:red; v14 --"p:qualifier/P2241"--> v15 end subgraph optional2["(optional)"] style optional2 fill:#bbf,stroke-dasharray: 5 5; v14 -."p:qualifier/P580".-> v4 end subgraph optional3["(optional)"] style optional3 fill:#bbf,stroke-dasharray: 5 5; v14 -."p:qualifier/P582".-> v2 end v12 --"p:P36"--> v16 v16 --"p:statement/P36"--> v17 subgraph optional4["(optional)"] style optional4 fill:#bbf,stroke-dasharray: 5 5; v16 -."p:qualifier/P580".-> v8 end subgraph optional5["(optional)"] style optional5 fill:#bbf,stroke-dasharray: 5 5; v16 -."p:qualifier/P582".-> v7 end v17 --"p:P374"--> v18 v18 --"p:statement/P374"--> v19 subgraph optional6["(optional)"] style optional6 fill:#bbf,stroke-dasharray: 5 5; v18 -."p:qualifier/P580".-> v6 end subgraph optional7["(optional)"] style optional7 fill:#bbf,stroke-dasharray: 5 5; v18 -."p:qualifier/P582".-> v5 end