/* ========================================================================== phase 1 : récupération des données depuis umap et calcul des PK auto ========================================================================== */ -- voir la documentation pour la création de la base de données -- on est obligé de créer des tables en Lambert 93 (EPSG:2154) (ou une CC conforme) -- car même si les tables originales sont déclarées en 3857 -- en fait les géoémtries sont en 4326 -- donc les calculs de longueur sont faux -- au moins en créant une table en dur en Lambert 93 / 2154 on est sûr des longueurs -- la table secteur gère les grands découpage de gestion DROP TABLE IF EXISTS secteur CASCADE ; CREATE TABLE secteur ( id integer, nom_br text, nom_fr text, km_reels integer, km_redadeg integer ); ALTER TABLE secteur OWNER to redadeg; -- et on insert ces données stables TRUNCATE TABLE secteur ; INSERT INTO secteur VALUES (1,'Karaez -> Rostren','Carhaix -> Rostrenen'); INSERT INTO secteur VALUES (2,'Rostren -> Plounevez-Moedeg','Rostrenen -> Plounevez-Moedec'); INSERT INTO secteur VALUES (3,'Plounevez-Moedeg -> Montroulez','Plounevez-Moedec -> Morlaix'); INSERT INTO secteur VALUES (4,'Montroulez -> Ar Faou','Morlaix -> Châteauneuf-du-Faou'); INSERT INTO secteur VALUES (5,'Ar Faou -> Kemperle','Châteauneuf-du-Faou -> Quimperlé'); INSERT INTO secteur VALUES (6,'Kemperle -> Redon','Quimperlé -> Redon'); INSERT INTO secteur VALUES (7,'Redon -> Tilheg','Redon -> Teillay'); INSERT INTO secteur VALUES (8,'Tilheg -> Roazhon','Teillay -> Rennes'); INSERT INTO secteur VALUES (9,'Roazhon -> Sant-Brieg','Rennes -> Saint-Brieuc'); INSERT INTO secteur VALUES (10,'Sant-Brieg -> Gwengamp','Saint-Brieuc -> Gwengamp'); INSERT INTO secteur VALUES (999,'test','test'); DROP TABLE IF EXISTS phase_1_trace CASCADE ; CREATE TABLE phase_1_trace ( ogc_fid integer, secteur_id int, ordre int, longueur numeric, the_geom geometry(LineString,2154), CONSTRAINT phase_1_trace_pkey PRIMARY KEY (ogc_fid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); DROP TABLE IF EXISTS phase_1_pk_vip CASCADE ; CREATE TABLE phase_1_pk_vip ( ogc_fid integer, name text, description text, the_geom geometry(Point,2154), CONSTRAINT phase_1_pk_vip_pkey PRIMARY KEY (ogc_fid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); -- on crée aussi une version correcte en 4326 pour export vers umap DROP TABLE IF EXISTS phase_1_trace_4326 ; CREATE TABLE phase_1_trace_4326 ( ogc_fid integer, name text, -- = section_nom secteur_id int, ordre int, longueur numeric, the_geom geometry(LineString,4326), CONSTRAINT phase_1_trace_4326_pkey PRIMARY KEY (ogc_fid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 4326) ); -- table des tronçons créés à partir des longs tracés DROP TABLE IF EXISTS phase_1_trace_troncons CASCADE ; CREATE TABLE phase_1_trace_troncons ( uid bigint, secteur_id int, ordre bigint, km bigint, km_reel bigint, longueur integer, the_geom geometry(LineString,2154), CONSTRAINT phase_1_trace_troncons_pkey PRIMARY KEY (uid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_1_trace OWNER to redadeg; ALTER TABLE phase_1_trace_4326 OWNER to redadeg; ALTER TABLE phase_1_pk_vip OWNER to redadeg; ALTER TABLE phase_1_trace_troncons OWNER to redadeg; -- table des PK auto en fin de tronçon /*DROP TABLE phase_1_pk_auto ; CREATE TABLE phase_1_pk_auto ( uid bigint, secteur character varying(25), km bigint, km_reel bigint, the_geom geometry(Point,2154), CONSTRAINT phase_1_pk_auto_pkey PRIMARY KEY (uid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) );*/ -- vue des PK auto en fin de tronçon DROP VIEW IF EXISTS phase_1_pk_auto ; CREATE VIEW phase_1_pk_auto AS SELECT uid, secteur_id, ordre, km, km_reel, ST_Line_Interpolate_Point(the_geom, 1)::geometry(Point, 2154) AS the_geom FROM phase_1_trace_troncons ORDER BY secteur_id ASC, ordre ASC, km ASC ; -- la même mais en 4326 pour export DROP VIEW IF EXISTS phase_1_pk_auto_4326 ; CREATE VIEW phase_1_pk_auto_4326 AS SELECT uid, secteur_id, ordre, km, km_reel, ST_Transform(the_geom,4326)::geometry(Point, 4326) AS the_geom FROM phase_1_pk_auto ORDER BY secteur_id ASC, ordre ASC, km ASC ; ALTER TABLE phase_1_pk_auto OWNER to redadeg; ALTER TABLE phase_1_pk_auto_4326 OWNER to redadeg; -- vue tableau de bord de synthèse DROP VIEW IF EXISTS phase_1_tdb ; CREATE VIEW phase_1_tdb AS SELECT t.secteur_id, s.nom_br, s.nom_fr, TRUNC( SUM(t.longueur)::numeric , 3) AS longueur_km, ROUND( SUM(t.longueur)::numeric ) AS longueur_km_arrondi FROM phase_1_trace t JOIN secteur s ON t.secteur_id = s.id GROUP BY secteur_id, nom_br, nom_fr ORDER BY secteur_id ; /* ========================================================================== phase 2 : calcul d'itinéraires en appui du réseau routier OSM ========================================================================== */ -- les couches PK venant de umap DROP TABLE IF EXISTS phase_2_pk_secteur CASCADE ; CREATE TABLE phase_2_pk_secteur ( id integer, name text, pgr_node_id integer, secteur_id integer, the_geom geometry(Point,2154), CONSTRAINT phase_2_pk_secteur_pkey PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_2_pk_secteur OWNER to redadeg; -- une vue en 4326 pour export DROP VIEW IF EXISTS phase_2_pk_secteur_4326 ; CREATE VIEW phase_2_pk_secteur_4326 AS SELECT pk.id, pk.name, s.id AS secteur_id, replace(s.nom_fr,' ','') AS nom_fr, replace(s.nom_br,' ','') AS nom_br, ST_Transform(pk.the_geom,4326)::geometry(Point, 4326) AS the_geom FROM phase_2_pk_secteur pk JOIN secteur s ON pk.id = s.id ORDER BY pk.id ; ALTER TABLE phase_2_pk_secteur_4326 OWNER to redadeg; -- la couche qui contient les lignes des routes venant de OSM DROP TABLE IF EXISTS osm_roads ; CREATE TABLE osm_roads ( id bigint, osm_id bigint, highway text, type text, oneway text, ref text, name_fr text, name_br text, the_geom geometry, CONSTRAINT osm_roads_pkey PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text OR geometrytype(the_geom) = 'MULTILINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE osm_roads OWNER to redadeg; -- la couche en version routable DROP TABLE IF EXISTS osm_roads_pgr ; CREATE TABLE osm_roads_pgr ( id bigint, osm_id bigint, highway text, type text, oneway text, ref text, name_fr text, name_br text, source bigint, target bigint, cost double precision, reverse_cost double precision, the_geom geometry, CONSTRAINT osm_roads_pgr_pkey PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text OR geometrytype(the_geom) = 'MULTILINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); CREATE INDEX osm_roads_pgr_source_idx ON osm_roads_pgr (source); CREATE INDEX osm_roads_pgr_target_idx ON osm_roads_pgr (target); ALTER TABLE osm_roads_pgr OWNER to redadeg; -- la couche des points pour nettoyer la couche de routage DROP TABLE IF EXISTS phase_2_point_nettoyage ; CREATE TABLE phase_2_point_nettoyage ( id serial, pt_id bigint, edge_id bigint, distance numeric, the_geom geometry, CONSTRAINT phase_2_point_nettoyage_pkey PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_2_point_nettoyage OWNER to redadeg; -- dans la base redadeg on chargera la couche osm_roads qui a été calculée -- à partir de données OSM -- 1. création d'un schéma qui va accueillir le réseau topologique de la couche osm_roads SELECT topology.CreateTopology('osm_roads_topo', 2154); -- la table qui va recevoir le résultat du calcul d'itinéraire DROP TABLE IF EXISTS phase_2_trace_pgr CASCADE; CREATE TABLE phase_2_trace_pgr ( secteur_id integer, -- info de routage path_seq bigint, node bigint, cost double precision, agg_cost double precision, -- info OSM osm_id bigint, highway text, type text, oneway text, ref text, name_fr text, name_br text, the_geom geometry, --CONSTRAINT phase_2_trace_pkey PRIMARY KEY (secteur_id, path_seq), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text OR geometrytype(the_geom) = 'MULTILINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_2_trace_pgr OWNER to redadeg; -- une vue en 4326 pour export DROP VIEW IF EXISTS phase_2_trace_pgr_4326 ; CREATE VIEW phase_2_trace_pgr_4326 AS SELECT secteur_id, path_seq, node, cost, agg_cost, osm_id, highway, type, oneway, ref, name_fr, name_br, ST_Transform(the_geom,4326)::geometry(LineString, 4326) AS the_geom FROM phase_2_trace_pgr ; ALTER TABLE phase_2_trace_pgr_4326 OWNER to redadeg; -- couche qui contient 1 ligne par secteur DROP TABLE IF EXISTS phase_2_trace_secteur CASCADE ; CREATE TABLE phase_2_trace_secteur ( secteur_id int, nom_fr text, nom_br text, longueur int, longueur_km numeric, the_geom geometry, CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_2_trace_secteur OWNER to redadeg; -- une vue en 4326 pour export DROP VIEW IF EXISTS phase_2_trace_secteur_4326 ; CREATE VIEW phase_2_trace_secteur_4326 AS SELECT secteur_id, nom_fr, nom_br, longueur, longueur_km, ST_Transform(the_geom,4326)::geometry(MultiLineString, 4326) AS the_geom FROM phase_2_trace_secteur ; ALTER TABLE phase_2_trace_secteur_4326 OWNER to redadeg; DROP TABLE IF EXISTS phase_2_trace_trous ; CREATE TABLE phase_2_trace_trous ( id serial, secteur_id int, the_geom geometry, CONSTRAINT phase_2_trace_trous_pkid PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE phase_2_trace_trous OWNER to redadeg; -- la table qui va contenir des tronçons de x m DROP TABLE IF EXISTS phase_2_trace_troncons ; CREATE TABLE phase_2_trace_troncons ( uid bigint, secteur_id int, ordre bigint, km bigint, km_reel bigint, longueur integer, -- info OSM osm_id bigint, highway text, type text, oneway text, ref text, name_fr text, name_br text, the_geom geometry, CONSTRAINT phase_2_trace_troncons_pkey PRIMARY KEY (uid), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); DROP VIEW IF EXISTS phase_2_tdb ; CREATE VIEW phase_2_tdb AS WITH total AS ( SELECT 0 AS secteur_id, 'Total' AS nom_fr, 'Hollad' AS nom_br, SUM(longueur_km) AS longueur_km FROM public.phase_2_trace_secteur GROUP BY 1 ) SELECT a.secteur_id, a.nom_fr, a.nom_br, a.longueur_km, b.km_reels AS longueur_km_attendu, -(b.km_reels - a.longueur_km) AS difference, TRUNC(a.longueur_km / (SELECT longueur_km FROM total) * 2020, 0) AS nb_km_redadeg --TRUNC((a.longueur_km / (SELECT longueur_km FROM total) * 2020) / b.km_reels, 3) AS longueur_km_redadeg FROM phase_2_trace_secteur a JOIN secteur b ON a.secteur_id = b.id UNION SELECT 0 AS secteur_id, 'Total' AS nom_fr, 'Hollad' AS nom_br, SUM(longueur_km) AS longueur_km, 0,0,0 FROM public.phase_2_trace_secteur GROUP BY 1 ORDER BY secteur_id ASC ; ALTER TABLE phase_2_tdb OWNER TO redadeg;