Projet

Général

Profil

Actions

Anomalie #10524

fermé

Requête extrêmement longue sur le serveur lors d'une mise à jour

Ajouté par Henri QUENEAU il y a plus de 5 ans. Mis à jour il y a plus de 3 ans.

Statut:
R&D - Terminé
Priorité:
2-Sérieux
Assigné à:
Version cible:
Début:
07/05/2019
Echéance:

Description

En tant qu'administrateur technique, lorsque je fais une mise à jour, il y a la requête ci-dessous qui est extrêmement longue car j'ai énormément de courrier en base.

DO $$ BEGIN
  IF (SELECT count(attname) FROM pg_attribute WHERE attrelid = (SELECT oid FROM pg_class WHERE relname = 'mlb_coll_ext') AND attname = 'recommendation_limit_date') = 1 THEN
    ALTER TABLE res_letterbox ADD COLUMN opinion_limit_date TIMESTAMP without TIME ZONE DEFAULT NULL;
    UPDATE res_letterbox SET opinion_limit_date =
    (
      SELECT recommendation_limit_date FROM mlb_coll_ext
      WHERE res_letterbox.res_id = mlb_coll_ext.res_id
    );
    ALTER TABLE mlb_coll_ext DROP COLUMN IF EXISTS recommendation_limit_date;
  END IF;
END$$;

Il faut ajouter une condition pour que ça marche mieux


DO $$ BEGIN
  IF (SELECT count(attname) FROM pg_attribute WHERE attrelid = (SELECT oid FROM pg_class WHERE relname = 'mlb_coll_ext') AND attname = 'recommendation_limit_date') = 1 THEN
    ALTER TABLE res_letterbox ADD COLUMN opinion_limit_date TIMESTAMP without TIME ZONE DEFAULT NULL;
    
UPDATE res_letterbox SET opinion_limit_date = mlb_coll_ext.recommendation_limit_date 
FROM mlb_coll_ext
WHERE res_letterbox.res_id = mlb_coll_ext.res_id
AND recommendation_limit_date IS NOT NULL;

    ALTER TABLE mlb_coll_ext DROP COLUMN IF EXISTS recommendation_limit_date;
  END IF;
END$$;

Mis à jour par Henri QUENEAU il y a plus de 5 ans

  • Assigné à Henri QUENEAU supprimé

Mis à jour par Emmanuel DILLARD il y a plus de 5 ans

  • Statut changé de A traiter à R&D - A étudier

Mis à jour par Florian AZIZIAN il y a plus de 5 ans

  • Tracker changé de Fonctionnalité à Anomalie
  • Projet changé de 298 à 299
  • Sujet changé de requête extrêmement longue sur le serveur lors d'une mise à jour à Requête extrêmement longue sur le serveur lors d'une mise à jour
  • Statut changé de R&D - A étudier à R&D - En cours
  • Assigné à mis à EDI PO
  • Version cible changé de 19.04 (Fin de vie) à 20.03 (Fin de vie)

Mis à jour par Emmanuel DILLARD il y a plus de 5 ans

  • Projet changé de 299 à 298
  • Statut changé de R&D - En cours à R&D - Terminé

Mis à jour par Emmanuel DILLARD il y a plus de 3 ans

  • Projet changé de 298 à Backlog Courrier
  • Version cible changé de 20.03 (Fin de vie) à 20.03 (Sécurité)
Actions

Formats disponibles : Atom PDF