10 | | Est-ce pertinent de faire cette modif ? Ou est-ce qu'on considère que pas possible d'avoir le même code pour des types de marques différents ? |
| 10 | Voici le code SQL pour faire cela (à lancer sur tous les schémas dont chaque utilisateur dispose hors schéma public, ref et topology) : |
| 11 | |
| 12 | select ref.updatesql('{"bgm","charente","fd80","logrami","migado","migradour","nat","ngm","pmp","saumonrhin","seinormigr","smatah"}', |
| 13 | ' |
| 14 | --Ajout de la colonne act_nmq_code dans tj_actionmarquage |
| 15 | ALTER TABLE tj_actionmarquage_act ADD COLUMN act_nmq_code character varying(4); |
| 16 | |
| 17 | --Mise à jour de ce champ par rapport au champ mqe_nmq_code |
| 18 | UPDATE tj_actionmarquage_act SET act_nmq_code=m.mqe_nmq_code FROM t_marque_mqe m where act_mqe_reference=m.mqe_reference; |
| 19 | |
| 20 | --On ajoute une contrainte not null sur le champ act_nmq_code |
| 21 | ALTER TABLE tj_actionmarquage_act ALTER COLUMN act_nmq_code SET NOT NULL; |
| 22 | |
| 23 | --On supprime les contrainte de clé étrangère / clé primaire |
| 24 | ALTER TABLE tj_actionmarquage_act DROP CONSTRAINT c_fk_act_mqe_reference; |
| 25 | ALTER TABLE t_marque_mqe DROP CONSTRAINT c_pk_mqe; |
| 26 | |
| 27 | --On les refait en ajoutant ce champ à la clé |
| 28 | ALTER TABLE t_marque_mqe ADD CONSTRAINT c_pk_mqe PRIMARY KEY (mqe_reference, mqe_nmq_code, mqe_org_code); |
| 29 | ALTER TABLE tj_actionmarquage_act ADD CONSTRAINT c_fk_act_mqe_reference FOREIGN KEY (act_mqe_reference, act_nmq_code, act_org_code) REFERENCES t_marque_mqe (mqe_reference, mqe_nmq_code, mqe_org_code) MATCH SIMPLE |
| 30 | ON UPDATE CASCADE ON DELETE NO ACTION; |
| 31 | '); |