/* ========================================================================== 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, objectif_km integer, km_redadeg integer ); ALTER TABLE secteur OWNER to redadeg; -- et on insert ces données stables TRUNCATE TABLE secteur ; INSERT INTO secteur VALUES (0,'Rak-loc''han','Pré-départ',13,0); INSERT INTO secteur VALUES (10,'Karaez -> Rostren','Carhaix -> Rostrenen',93,819); INSERT INTO secteur VALUES (20,'Rostren -> Plounevez-Moedeg','Rostrenen -> Plounevez-Moedec',99,818); INSERT INTO secteur VALUES (30,'Plounevez-Moedeg -> Montroulez','Plounevez-Moedec -> Morlaix',230,818); INSERT INTO secteur VALUES (40,'Montroulez -> Ar Faou','Morlaix -> Châteauneuf-du-Faou',223,819); INSERT INTO secteur VALUES (50,'Ar Faou -> Kemperle','Châteauneuf-du-Faou -> Quimperlé',264,818); INSERT INTO secteur VALUES (60,'Kemperle -> Kamorzh','Quimperlé -> Camors',212,820); INSERT INTO secteur VALUES (61,'Kamorzh -> Redon','Camors -> Redon',122,927); INSERT INTO secteur VALUES (70,'Redon -> Savenneg','Redon -> Savenay',100,862); INSERT INTO secteur VALUES (71,'Savenneg -> Naoned','Savenay -> Nantes',20,1620); INSERT INTO secteur VALUES (72,'Naoned -> Tilheg','Nantes -> Teillay',122,865); INSERT INTO secteur VALUES (80,'Tilheg -> Roazhon','Teillay -> Rennes',58,935); INSERT INTO secteur VALUES (90,'Roazhon -> Dinan','Rennes -> Dinan',215,925); INSERT INTO secteur VALUES (91,'Dinan -> Sant-Brieg','Dinan -> Saint-Brieuc',105,824); INSERT INTO secteur VALUES (100,'Sant-Brieg -> Gwengamp','Saint-Brieuc -> Gwengamp',145,821); 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; -- les polygones des communes DROP TABLE IF EXISTS osm_communes ; CREATE TABLE osm_communes ( gid serial, insee character varying(80), nom character varying(80), wikipedia character varying(80), surf_ha numeric, the_geom geometry, CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POLYGON'::text OR geometrytype(the_geom) = 'MULTIPOLYGON'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154), CONSTRAINT osm_communes_pkey PRIMARY KEY (gid) ); CREATE INDEX osm_communes_geom_idx ON osm_communes USING gist(the_geom); ALTER TABLE osm_communes OWNER to redadeg; /* INSERT INTO osm_communes SELECT gid, insee, nom, wikipedia, surf_ha, ST_Transform(ST_SetSRID(geom,4326),2154) AS the_geom FROM osm_communes_4326 ORDER BY insee ASC ; */ -- la couche qui contient les lignes des routes venant de OSM DROP TABLE IF EXISTS osm_roads ; CREATE TABLE osm_roads ( uid bigint NOT NULL, 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 (uid), 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_geom_idx ON osm_roads USING gist(the_geom); 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; -- couche de polygones pour supprimer le contenu de osm_roads_pgr pour la gestion des boucles DROP TABLE IF EXISTS osm_roads_pgr_patch_mask ; CREATE TABLE osm_roads_mask ( id serial, name text, the_geom geometry, CONSTRAINT osm_roads_pgr_patch_mask_pkid PRIMARY KEY (id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POLYGON'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 2154) ); ALTER TABLE osm_roads_pgr_patch_mask OWNER to redadeg; -- couche jumelle de osm_roads mais avec des lignes gérées à la main pour les boucles DROP TABLE IF EXISTS osm_roads_pgr_patch ; CREATE TABLE osm_roads_pgr_patch ( id serial, 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_patch_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_pgr_patch OWNER to redadeg; -- 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; -- ça sert à quoi ça ? 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; /* ========================================================================== phase 3 : calcul des PK auto ========================================================================== */ DROP TABLE IF EXISTS phase_3_trace_troncons ; CREATE TABLE phase_3_trace_troncons ( troncon_id bigint, secteur_id int, the_geom geometry, CONSTRAINT phase_3_trace_troncons_pkey PRIMARY KEY (troncon_id), --CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text), --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_3_pk_auto_4326 OWNER TO redadeg; -- la même couche en 4326 DROP VIEW IF EXISTS phase_3_trace_troncons_4326 ; CREATE VIEW phase_3_trace_troncons_4326 AS SELECT troncon_id, secteur_id, ST_Transform(the_geom,4326)::geometry(LineString, 4326) AS the_geom FROM phase_3_trace_troncons ; ALTER TABLE phase_3_trace_troncons_4326 OWNER TO redadeg; DROP TABLE IF EXISTS phase_3_trace_secteurs ; CREATE TABLE phase_3_trace_secteurs ( secteur_id int, nom_fr text, nom_br text, km_reels numeric(2), the_geom geometry, CONSTRAINT phase_3_trace_secteurs_pkey PRIMARY KEY (secteur_id), --CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'LINESTRING'::text OR geometrytype(the_geom) = 'MULTILINESTRING'::text), --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_3_trace_secteurs OWNER TO redadeg; -- la même couche en 4326 DROP VIEW IF EXISTS phase_3_trace_secteurs_4326 ; CREATE VIEW phase_3_trace_secteurs_4326 AS SELECT secteur_id, nom_fr, nom_br, km_reels, ST_Transform(the_geom,4326)::geometry(LineString, 4326) AS the_geom FROM phase_3_trace_secteurs ; ALTER TABLE phase_3_trace_secteurs_4326 OWNER TO redadeg; -- la couche des PK calculés automatiquement DROP TABLE IF EXISTS phase_3_pk_auto ; CREATE TABLE phase_3_pk_auto ( pk_id integer, pk_x numeric(8,1), pk_y numeric(8,1), pk_long numeric(10,8), pk_lat numeric(10,8), length_real numeric(6,2), length_theorical integer, secteur_id integer, municipality_admincode text, municipality_postcode text, municipality_name_fr text, municipality_name_br text, way_osm_id bigint, way_highway text, way_type text, way_oneway text, way_ref text, way_name_fr text, way_name_br text, the_geom geometry, CONSTRAINT phase_3_pk_auto_pkey PRIMARY KEY (pk_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_3_pk_auto OWNER TO redadeg; -- la même couche en 4326 DROP VIEW IF EXISTS phase_3_pk_auto_4326 ; CREATE VIEW phase_3_pk_auto_4326 AS SELECT pk_id, pk_x, pk_y, pk_long, pk_lat, length_real, length_theorical, secteur_id, municipality_admincode, municipality_postcode, municipality_name_fr, municipality_name_br, way_osm_id, way_highway, way_type, way_oneway, way_ref, way_name_fr, way_name_br, ST_Transform(the_geom,4326)::geometry(Point, 4326) AS the_geom FROM phase_3_pk_auto ; ALTER TABLE phase_3_pk_auto_4326 OWNER TO redadeg; -- couche de lignes simples directes de PK à PK DROP TABLE IF EXISTS phase_3_pk_sens_verif ; CREATE TABLE phase_3_pk_sens_verif ( secteur_id integer, the_geom geometry, 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_3_pk_sens_verif OWNER TO redadeg; -- la même couche en 4326 DROP VIEW IF EXISTS phase_3_pk_sens_verif_4326 ; CREATE VIEW phase_3_pk_sens_verif_4326 AS SELECT secteur_id, ST_Transform(the_geom,4326)::geometry(LineString, 4326) AS the_geom FROM phase_3_pk_sens_verif ; ALTER TABLE phase_3_pk_sens_verif_4326 OWNER TO redadeg; /* ========================================================================== phase 4 : création de la couche des PK à charger dans umap pour la phase 5 ========================================================================== */ DROP VIEW IF EXISTS phase_4_pk_auto_4326 ; CREATE VIEW phase_4_pk_auto_4326 AS SELECT pk_id, secteur_id, ST_Transform(the_geom,4326)::geometry(Point, 4326) AS the_geom FROM phase_3_pk_auto ; ALTER TABLE phase_4_pk_auto_4326 OWNER TO redadeg; /* ========================================================================== phase 5 : gestion manuelle ========================================================================== */ -- la table des PK avant modifications manuelles -- en WGS85 / EPSG:4326 pour se simplier les contrôles DROP TABLE IF EXISTS phase_5_pk_ref ; CREATE TABLE phase_5_pk_ref ( pk_id integer, pk_x numeric(8,1), pk_y numeric(8,1), pk_long numeric(10,8), pk_lat numeric(10,8), length_real numeric(6,2), length_theorical integer, secteur_id integer, municipality_admincode text, municipality_postcode text, municipality_name_fr text, municipality_name_br text, way_osm_id bigint, way_highway text, way_type text, way_oneway text, way_ref text, way_name_fr text, way_name_br text, the_geom geometry, CONSTRAINT phase_5_pk_ref_pkey PRIMARY KEY (pk_id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 4326) ) ; ALTER TABLE phase_5_pk_ref OWNER TO redadeg; -- on charge cette table avec les données finales de la phase 3 INSERT INTO phase_5_pk_ref SELECT * FROM phase_4_pk_auto_4326 ; -- la table finale DROP TABLE IF EXISTS phase_5_pk ; CREATE TABLE phase_5_pk ( pk_id integer, pk_x numeric(8,1), pk_y numeric(8,1), pk_long numeric(10,8), pk_lat numeric(10,8), length_real numeric(6,2), length_theorical integer, secteur_id integer, municipality_admincode text, municipality_postcode text, municipality_name_fr text, municipality_name_br text, way_osm_id bigint, way_highway text, way_type text, way_oneway text, way_ref text, way_name_fr text, way_name_br text, the_geom geometry, CONSTRAINT phase_5_pk_pkey PRIMARY KEY (pk_id), CONSTRAINT enforce_geotype_the_geom CHECK (geometrytype(the_geom) = 'POINT'::text), CONSTRAINT enforce_srid_the_geom CHECK (st_srid(the_geom) = 4326) ) ; ALTER TABLE phase_5_pk OWNER TO redadeg;