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

Linux Discussion :

[bash] problème d'appel d'une variable dans une boucle.


Sujet :

Linux

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2
    Points : 1
    Points
    1
    Par défaut [bash] problème d'appel d'une variable dans une boucle.
    Bonjour, je suis en train de faire un script pour sauvegarder entre autres choses des bases Mysql. J'essaie de garder le script le plus général possible, histoire de faciliter sa ré-utilisation.

    Dans mon code J'initialise un compteur avec une valeur donnée. Puis je lance une boucle while dont la condition est le fait que le compteur est différent de 0.
    Puis j'essaie de faire un dump de mes bases pour chaque valeur du compteur.
    J'ai une variable dbn qui contient le string DB_NAME concaténer avec la valeur de mon compteur dbc.

    Le problème c'est qu'il faudrait que j'appelle la valeur d'une variable avec la valeur d'une variable, et je ne sais pas comment faire, ni même si c'est possible.

    J'ai bien pensé à travailler avec un tableau pour contourner le problème mais si je pouvais éviter (je n'ai pas trop l'habitude des tableaux...).

    (Dans le code ci-dessous je n'ai mis la déclaration que pour les variables où le problème ce situe histoire de gagner de la place)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    #!/bin/bash
    
    #liste des bases à sauvegarder
    DB_NAME1="oceb"
    DB_NAME2="gldb"
    DB_NAME3="mysql"
    DB_COUNT="3"
    
    #dbc compteur désignant numéro de la base en cours de traitement 
    dbc="$DB_COUNT"
    
    #dump des bases
    while [ $dbc != "0" ]
      do
    
        dbn="DB_NAME"$dbc""
    
        echo "" >> $LOG_FILE
        echo "Dump de la base $dbn" >> $LOG_FILE
      
        mysqldump -v --add-drop-table --complete-insert --extended-insert
     --quote-names --host=$SQL_HOST --user="$SQL_USER" 
    --password="$SQL_PWD" $"$dbn" > $DIR_SAV_MK/$dbn_$DATE.sql
     2>> $LOG_FILE
      
        let dbc=dbc-1
    
      done
    Donc si quelqu'un avait une solution ou au moins une piste à explorer.
    Merci.

  2. #2
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Points : 2 505
    Points
    2 505
    Par défaut
    Tu peux utiliser eval :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    # a=b
    # b=c
    # eval echo \$$a
    c

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup. Ci-dessous le code modifié (uniquement la partie concernée)


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        dbn="DB_NAME"$dbc""
        dbn=$(eval echo \$$dbn)
    
        mysqldump -v --add-drop-table --complete-insert --extended-insert
     --quote-names --host=$SQL_HOST --user="$SQL_USER" 
    --password="$SQL_PWD" $dbn > $DIR_SAV_MK/$dbn_$DATE.sql
     2>> $LOG_FILE

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  2. Récupérer le nom d'une colonne d'une table dans une variable
    Par mimi51340 dans le forum Général Java
    Réponses: 4
    Dernier message: 13/03/2008, 14h23
  3. Réponses: 4
    Dernier message: 29/01/2008, 11h12
  4. Réponses: 1
    Dernier message: 15/02/2007, 00h24
  5. Mettre une valeur d'une table dans une variable
    Par Raphou96 dans le forum Access
    Réponses: 5
    Dernier message: 06/02/2006, 15h19

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