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

Requêtes MySQL Discussion :

Ajouter un commentaire sur une colonne


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut Ajouter un commentaire sur une colonne
    Bonjour,

    j'ai un petit soucis avec ma base de données mysql 5.0 : je dois ajouter des commentaires aux colonnes de ma table

    J'ai trouvé cette syntaxe :

    ALTER TABLE <NOMTABLE> MODIFY <COLONNE> <TYPECOLONNE> COMMENT '<MonCommentaire>'
    Mon problème c'est que je fais ces modifications sur la table à partir d'un fichier ne contenant que les noms de tables et colonnes (donc pas le type!)

    Est ce que il y a moyen de contourner cette syntaxe??

  2. #2
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    139
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2006
    Messages : 139
    Points : 147
    Points
    147
    Par défaut
    Tu n'es pas obligé de préciser des modifications de champs, tu peux juste mettre à jour le commentaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE maTable COMMENT 'Commentaire';

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Merci de ta réponse, mais cette syntaxe permet d'ajouter un commentaire sur la table, et non sur les champs si ?

  4. #4
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    139
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2006
    Messages : 139
    Points : 147
    Points
    147
    Par défaut
    Autant pour moi j'ai lu un peu vite...

    Tu peux peut etre récupérer les champs avec un DESC sur ta table. A partir de là tu peux récupérer les propriétés des champs... mais bon ça demande un traitement !

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Très bonne idée... DESC <MA TABLE> me donne effectivement le type de chaque champ, mais est ce que tu sais comment récupérer le champ TYPE?

    merci de ton aide en tout cas.
    Brice

  6. #6
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    139
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2006
    Messages : 139
    Points : 147
    Points
    147
    Par défaut
    Peut-être mieux en passant par information_schema :

    Pour récupérer le commentaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT COLUMN_COMMENT
    FROM information_schema.COLUMNS
    WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'donnee' AND COLUMN_NAME='heure';
    Pour le modifier :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE information_schema.COLUMNS
    SET COLUMN_COMMENT = 'Test de commentaire'
    WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'donnee' AND COLUMN_NAME='heure';
    Par contre j'ai une erreur sur la requête de modification :
    Access denied for user 'root'@'%' to database 'information_schema'

    Je ne sais pas s'il est possible de modifier les droits sur "information_schema".

    Au cas où ça ne marcherait pas, tu peux récupérer les champs "COLUMN_TYPE", "COLUMN_DEFAULT", "IS_NULLABLE", "CHARACTER_SET_NAME", "COLLATION_NAME" et "EXTRA" pour reconstruire la requête de modification de champ.

    Autre piste :
    et tu en parses le résultat.

    Voilà, bon courage
    A+

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Salut,
    merci de ta réponse...

    à prioris on ne peut pas modifier le TABLE_SCHEMA (si je me souviens bien c'est une sorte de "table virtuelle" dont la modification n'est pas autorisée )

    je continue a chercher... si je trouve un truc je vous tient au courant...

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Nouvelle question toujours dans le registre des commentaires...

    Est il possible d'ajouter un commentaire sur une vue?? (j'ai pas l'impression )

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Bonjour à tous,
    le week-end passé, le problème est toujours là

    enfin bon j'avance... mais doucettement comme on dit!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     DELIMITER |
     
    CREATE PROCEDURE CommentaireColonne (base_com VARCHAR(255), table_com VARCHAR(255), colonne_com VARCHAR(255), commentaire_com VARCHAR(255))
    BEGIN
    DECLARE type_com VARCHAR(64);
    SELECT DATA_TYPE INTO type_com FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = base_com AND TABLE_NAME=table_com AND COLUMN_NAME=colonne_com;
    ALTER TABLE table_com MODIFY colonne_com type_com COMMENT commentaire_com;
    END;
    |
     
    DELIMITER ;
    Comme vous pouvez le voir ci-dessus ... je me suis lancé dans une procédure histoire de remplir mes commentaires
    MAIS Elle ne marche pas ... ya un soucis à prioris sur l'interprétaton de type_com... enfin je comprends plus grand chose! Si quelqu'un peut m'aider je lui ferais un p'tit bisou

Discussions similaires

  1. Réponses: 9
    Dernier message: 10/02/2011, 10h25
  2. [phpMyAdmin] Ajouter des commentaires sur une table
    Par huit_six dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 21/05/2010, 11h35
  3. Réponses: 1
    Dernier message: 27/07/2009, 16h11
  4. Réponses: 5
    Dernier message: 03/11/2008, 16h59
  5. Réponses: 4
    Dernier message: 12/08/2008, 12h20

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