IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Informix Discussion :

L'équivalent de la commande truncate en informix


Sujet :

Informix

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2003
    Messages
    120
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 120
    Points : 65
    Points
    65
    Par défaut L'équivalent de la commande truncate en informix
    Bonjour à tous,

    J'aimerais savoir si la commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     truncate table nom_table
    fonctionne sous informix ou bien y aurait-il une équivalence?
    J'ai une table qui contient plusieurs données et quand je tente de la vider avec , le système se plante.

    Merci de votre collaboration.

  2. #2
    Membre averti Avatar de blackstreet
    Inscrit en
    Avril 2004
    Messages
    304
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 304
    Points : 335
    Points
    335
    Par défaut
    Bonjour,

    Oui, La commande Tuncate fonctionne sous informix. mais à partir de la version 10 de Informix :


  3. #3
    Membre habitué
    Homme Profil pro
    Achitecte Informix SGBD et applications - IBM Champion - Data Management - Board of Directors IIUG
    Inscrit en
    Octobre 2010
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Achitecte Informix SGBD et applications - IBM Champion - Data Management - Board of Directors IIUG
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2010
    Messages : 105
    Points : 162
    Points
    162
    Par défaut
    Le système te plante très vraisemblablement parce que tu as provoqué une "long transaction". C'est un cas très courant dans IDS, qui n'est pas un plantage en soi, mais un simple dépasser de capacité. J'explique brièvement:
    tu as une base de données journalisée, donc ton moteur conserve les informations qui permettront de remettre tes données dans l'état initial si l'application décide de rollbacker la transaction.
    Ces informations sont conservées dans le "logical log" ( pas le physical log qui ne fait que conserver l'image-avant des pages de données), qui est un ensemble de "fichiers" contenu en général dans le rootdbspace, ou bien un dbspace spécifique. Cet ensemble a une taille limitée, et fonctionne en remplissage cyclique: le 1er logical log est plein, on passe au 2ème, et ainsi de suite jusqu'au dernier. Lorsque le dernier est plein, on repasse en théorie au premier, mais à condition que:
    * celui-ci ait été libéré, c'est à dire qu'il ait été backupé par ontape -c/a ou onbar,
    * et qu'il ne contienne plus aucune information concernant une transaction en cours d'exécution.

    Si l'une de ces deux conditions n'est pas respectées, ton logical log est plein et ton système est bloqué, ce qui peut dans certains cas se terminer en situation critique où l'issue est le restore de ton instance. En cas d'"oubli" du backup des logical logs, il suffit de les backuper et si tu récupères de l'espace, tu es hors de danger.

    Afin d'éviter une situation de blocage total où le logical log serait plein et ne pourrait plus exécuter le rollback de ta transaction, interviennent à ce stade deux paramètres ONCONFIG, qui sont LTXHWM et LTXEHWM: limite de marée-haute des long transactions. LTXHWM, un pourcentage, déterminera le seuil de remplissage du logical log à partir duquel la transaction fautive est rollbackée. ( erreur -458 ), et dont le rollback a besoin d'écrire dans le logical log. LTXEHWM déterminera, en cas d'existence de plusieurs longues transactions, quelle transaction aura l'exclusivité du rollback, en mettant toutes les autres en pause.

    C'est donc une situation potentiellement très embarrassante qui peut mener au restore de l'instance.

    Les solutions:

    Au delà du travail du DBA de bien configurer la taille du logical log ( en fonction de ce que fait l'application en général ), et de LTXHWM et LTXEHWM, les techniques suivantes sont d'une grande aide:
    * l'avènement ( enfin ) de la commande TRUNCATE, disponible à partir de 10.0 xC4
    * le workaround stupide mais très efficace si applicable: DROP TABLE et CREATE TABLE avec le même schéma si possible et ton DBA t'autorise à le faire;-)
    * l'utilisation de table de type RAW TABLE ( qui peut être établi temporairement et rebasculé à STANDARD), qui désactive la journalisation seulement sur cette table; Disponible à partir de 10.00.xC3. Très intéressant quand tu as une possible long transaction mais que tu ne peux pas dropper la table.

    Voila j'espère que celà apportera de l'eau à ton moulin et au moulin de ceux qui ressentiront les mêmes sympômes.

    Eric

Discussions similaires

  1. POWERSHELL : équivalent de la commande AWK
    Par tibal dans le forum Windows
    Réponses: 6
    Dernier message: 10/03/2008, 11h42
  2. équivalent de la commande trace de Linux
    Par Chatbour dans le forum Windows
    Réponses: 3
    Dernier message: 29/12/2007, 21h02
  3. Command key avec informix 4gl
    Par amine556 dans le forum Informix
    Réponses: 3
    Dernier message: 26/11/2007, 10h11
  4. équivalent de la commande MERGE dans mySQL ?
    Par Ekimasu dans le forum Requêtes
    Réponses: 1
    Dernier message: 08/10/2007, 21h45
  5. équivalant de la commande MINUS en MySQL
    Par El Saigneur dans le forum Requêtes
    Réponses: 7
    Dernier message: 01/09/2004, 17h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo