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

Shell et commandes GNU Discussion :

Affecter une valeur à une variable avec requête SQL


Sujet :

Shell et commandes GNU

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    799
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 799
    Points : 225
    Points
    225
    Par défaut Affecter une valeur à une variable avec requête SQL
    bonjour à tous,
    Je suis tout nouveau dans le monde du shell et j'aurais besoin d'affecter une valeur à une variable de travail par une requête sql.
    M a requete fait un count(*) et mets le résultat dans une variable comme en PL/SQL je ne sais pas si c'est possible d e créer ce genre de requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    cumul=O
    echo "select count(*) into $cumul from tstt;"  >> ${FIC_SQL}
    echo "commit;"     >> ${FIC_SQL}
    echo $cumul
    à l' exécution le shell ne me fait pas d'erreur mais m'affiche O au lieu du nombre de lignes qui est 41

    Si quelqu'un peut m'aider merçi

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 100
    Points : 28 393
    Points
    28 393
    Par défaut
    Malheureusement, ce n'est pas aussi simple.

    D'abord, je ne vois pas dans le code où et comment tu exécutes ta requête SQL.
    Ensuite, les variables SQL et celles du shell ne se "connaissent" pas

    Ce que tu peux faire, c'est faire afficher par ta requête le résultat de ton comptage, récupérer cet affichage et l'affecter à la variable shell.

    Quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cumul=$(execute_sql "select count(*) from tstt;")

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    799
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 799
    Points : 225
    Points
    225
    Par défaut réponse à moi même
    bonjour à tous,
    En fait j'ai la solution grâce à un collègue :
    En fait il faut créer une fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    nbRow() {
      cumul=`sqlplus -s $(ora_dba) << -EOF
       set pause off heading off feed off pagesize 0;
       select count(*) from tstt;
       exit;
       EOF`  
       echo $cumul
    puis affecter le résultat ou la valeur de cette fonction à une variable :
    puis afficher cette variable et là ça marche :
    Ca pourra aider quelqu'un...

  4. #4
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 584
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 584
    Points : 19 461
    Points
    19 461
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    nbRow() {
    sqlplus -s $(ora_dba) << -EOF
       set pause off heading off feed off pagesize 0;
       select count(*) from tstt;
       exit;
    EOF
    }
    
    tot=$(nbRow)
    #puis, plus tard
    echo "$tot"
    mais bon, l'usage d'une fonction est facultatif
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    tot=$(sqlplus -s $(ora_dba) << EOF
       set pause off heading off feed off pagesize 0;
       select count(*) from tstt;
       exit;
    EOF
    )

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/09/2010, 16h05
  2. Réponses: 3
    Dernier message: 14/05/2009, 17h53
  3. Inclure une variable dans requête SQL
    Par Mvu dans le forum Visual Studio
    Réponses: 2
    Dernier message: 04/07/2008, 09h13
  4. affecter une valeur à une Variable public
    Par mnssylvain dans le forum VBA Access
    Réponses: 10
    Dernier message: 28/01/2007, 12h39
  5. [MySQL] Introduire une variable dans requête SQL, insérer des données à la volée
    Par Ronan.f dans le forum PHP & Base de données
    Réponses: 18
    Dernier message: 29/04/2006, 22h10

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