Skip to content

Instantly share code, notes, and snippets.

@AntoineAugusti
Last active December 2, 2021 16:08
Show Gist options
  • Save AntoineAugusti/53cff357e6d76e6148928bda19fdf0c9 to your computer and use it in GitHub Desktop.
Save AntoineAugusti/53cff357e6d76e6148928bda19fdf0c9 to your computer and use it in GitHub Desktop.
Création des tables du modèle relationnel pour SECMAR
-- Testé avec PostgreSQL v10
DROP TYPE IF EXISTS mois_francais CASCADE;
CREATE TYPE mois_francais AS enum('Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre');
DROP TYPE IF EXISTS jours_semaine_francais CASCADE;
CREATE TYPE jours_semaine_francais AS enum('Lundi', 'Mardi', 'Mercredi', 'Jeudi', 'Vendredi', 'Samedi', 'Dimanche');
DROP TYPE IF EXISTS phase_journee CASCADE;
CREATE TYPE phase_journee AS enum('matinée', 'déjeuner', 'après-midi', 'nuit');
DROP TYPE IF EXISTS noms_cross CASCADE;
CREATE TYPE noms_cross AS enum('Adge', 'Antilles-Guyane', 'Corse', 'Corsen', 'Étel', 'Gris-Nez', 'Guadeloupe', 'Guyane', 'Jobourg', 'La Garde', 'La Réunion', 'Martinique', 'Mayotte', 'Nouvelle-Calédonie', 'Polynésie', 'Soulac');
DROP TABLE IF EXISTS public.operations CASCADE;
CREATE TABLE public.operations (
"operation_id" bigint primary key,
"type_operation" varchar(3),
"pourquoi_alerte" varchar(50),
"moyen_alerte" varchar(100) not null,
"qui_alerte" varchar(100) not null,
"categorie_qui_alerte" varchar(100) not null,
"cross" noms_cross not null,
"departement" varchar(100),
"est_metropolitain" boolean,
"evenement" varchar(100) not null,
"categorie_evenement" varchar(50) not null,
"autorite" varchar(100) not null,
"seconde_autorite" varchar(100),
"zone_responsabilite" varchar(50) not null,
"latitude" numeric(7, 4),
"longitude" numeric(7, 4),
"vent_direction" smallint,
"vent_direction_categorie" varchar(10),
"vent_force" smallint,
"mer_force" smallint,
"date_heure_reception_alerte" timestamp with time zone not null,
"date_heure_fin_operation" timestamp with time zone not null,
"numero_sitrep" smallint not null,
"cross_sitrep" varchar(50) not null,
"fuseau_horaire" varchar(25) not null
);
CREATE INDEX ON operations(type_operation);
CREATE INDEX ON operations(pourquoi_alerte);
CREATE INDEX ON operations("cross");
CREATE INDEX ON operations(departement);
CREATE INDEX ON operations(date_heure_reception_alerte);
CREATE INDEX ON operations(date_heure_fin_operation);
DROP TABLE IF EXISTS public.flotteurs;
CREATE TABLE public.flotteurs (
"operation_id" bigint references operations on delete cascade,
"numero_ordre" smallint not null,
"pavillon" varchar(50),
"resultat_flotteur" varchar(50) not null,
"type_flotteur" varchar(50) not null,
"categorie_flotteur" varchar(50) not null,
"numero_immatriculation" varchar(40)
);
CREATE INDEX ON flotteurs(operation_id);
CREATE INDEX ON flotteurs(resultat_flotteur);
CREATE INDEX ON flotteurs(type_flotteur);
CREATE INDEX ON flotteurs(categorie_flotteur);
DROP TABLE IF EXISTS public.resultats_humain;
CREATE TABLE public.resultats_humain (
"operation_id" bigint references operations on delete cascade not null,
"categorie_personne" varchar(50) not null,
"resultat_humain" varchar(50) not null,
"nombre" smallint not null,
"dont_nombre_blesse" smallint not null
);
CREATE INDEX ON resultats_humain(operation_id);
CREATE INDEX ON resultats_humain(categorie_personne);
CREATE INDEX ON resultats_humain(resultat_humain);
DROP TABLE IF EXISTS public.operations_stats;
CREATE TABLE public.operations_stats (
"operation_id" bigint primary key references operations on delete cascade not null,
"date" date not null,
"annee" smallint not null,
"mois" smallint not null,
"jour" smallint not null,
"mois_texte" mois_francais not null,
"semaine" smallint not null,
"annee_semaine" varchar(7) not null,
"jour_semaine" jours_semaine_francais not null,
"est_weekend" boolean not null,
"est_jour_ferie" boolean not null,
"est_vacances_scolaires" boolean,
"phase_journee" phase_journee,
"concerne_plongee" boolean not null,
"distance_cote_metres" int,
"distance_cote_milles_nautiques" numeric(6, 2),
"est_dans_stm" boolean not null,
"nom_stm" varchar(50),
"est_dans_dst" boolean not null,
"nom_dst" varchar(50),
"maree_port" varchar(50),
"maree_coefficient" smallint,
"maree_categorie" varchar(6),
"nombre_personnes_blessees" smallint not null,
"nombre_personnes_assistees" smallint not null,
"nombre_personnes_decedees" smallint not null,
"nombre_personnes_decedees_accidentellement" smallint not null,
"nombre_personnes_decedees_naturellement" smallint not null,
"nombre_personnes_disparues" smallint not null,
"nombre_personnes_impliquees_dans_fausse_alerte" smallint not null,
"nombre_personnes_retrouvees" smallint not null,
"nombre_personnes_secourues" smallint not null,
"nombre_personnes_tirees_daffaire_seule" smallint not null,
"nombre_personnes_tous_deces" smallint not null,
"nombre_personnes_tous_deces_ou_disparues" smallint not null,
"nombre_personnes_impliquees" smallint not null,
"nombre_personnes_blessees_sans_clandestins" smallint not null,
"nombre_personnes_assistees_sans_clandestins" smallint not null,
"nombre_personnes_decedees_sans_clandestins" smallint not null,
"nombre_personnes_decedees_accidentellement_sans_clandestins" smallint not null,
"nombre_personnes_decedees_naturellement_sans_clandestins" smallint not null,
"nombre_personnes_disparues_sans_clandestins" smallint not null,
"nombre_personnes_impliquees_dans_fausse_alerte_sans_clandestins" smallint not null,
"nombre_personnes_retrouvees_sans_clandestins" smallint not null,
"nombre_personnes_secourues_sans_clandestins" smallint not null,
"nombre_personnes_tirees_daffaire_seule_sans_clandestins" smallint not null,
"nombre_personnes_tous_deces_sans_clandestins" smallint not null,
"nombre_personnes_tous_deces_ou_disparues_sans_clandestins" smallint not null,
"nombre_personnes_impliquees_sans_clandestins" smallint not null,
"nombre_flotteurs_commerce_impliques" smallint not null,
"nombre_flotteurs_peche_impliques" smallint not null,
"nombre_flotteurs_plaisance_impliques" smallint not null,
"nombre_flotteurs_loisirs_nautiques_impliques" smallint not null,
"nombre_aeronefs_impliques" smallint not null,
"nombre_flotteurs_autre_impliques" smallint not null,
"nombre_flotteurs_annexe_impliques" smallint not null,
"nombre_flotteurs_autre_loisir_nautique_impliques" smallint not null,
"nombre_flotteurs_canoe_kayak_aviron_impliques" smallint not null,
"nombre_flotteurs_engin_de_plage_impliques" smallint not null,
"nombre_flotteurs_kitesurf_impliques" smallint not null,
"nombre_flotteurs_plaisance_voile_legere_impliques" smallint not null,
"nombre_flotteurs_plaisance_a_moteur_moins_8m_impliques" smallint not null,
"nombre_flotteurs_plaisance_a_moteur_plus_8m_impliques" smallint not null,
"nombre_flotteurs_plaisance_a_voile_impliques" smallint not null,
"nombre_flotteurs_planche_a_voile_impliques" smallint not null,
"nombre_flotteurs_ski_nautique_impliques" smallint not null,
"nombre_flotteurs_surf_impliques" smallint not null,
"nombre_flotteurs_vehicule_nautique_a_moteur_impliques" smallint not null,
"sans_flotteur_implique" boolean not null
);
CREATE INDEX ON operations_stats(operation_id);
CREATE INDEX ON operations_stats("date");
CREATE INDEX ON operations_stats(annee);
CREATE INDEX ON operations_stats(phase_journee);
CREATE INDEX ON operations_stats(concerne_plongee);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment