Script shell et SQL

Résolu
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   -  
zipe31 Messages postés 36402 Date d'inscription   Statut Contributeur Dernière intervention   -
Bonjour,

Je créé un script shell dans lequel j'exécute une requête SQL qui me retourne juste un nombre. Ce nombre je veux le stocké dans une variable mais je n'y arrive pas. Je vous mets mon code afin de savoir d'où provient mon erreur.

var='sqlplus user@SID/pwd << ABC
set head off
select count(*) as "fichier" from MATABLE;
exit;
ABC'
echo $(date +%d-%m-%y" "%H:%M:%S ) "Nombre de fichiers : ${var} " >> requete.txt


Par avance merci.


A voir également:

8 réponses

zipe31 Messages postés 36402 Date d'inscription   Statut Contributeur Dernière intervention   6 431
 
Salut,

Que renvoie la commande seule exactement :

sqlplus user@SID/pwd << ABC
set head off
select count(*) as "fichier" from MATABLE;
exit;
ABC


1
dna.factory Messages postés 26003 Date d'inscription   Statut Modérateur Dernière intervention   1 618
 
personnellement, quand je fait un select count(*) from table (que ce soit en ingres (on se moque pas) ou en postgres), j'obtiens un résultat du type :

count
-------
38613
(1 row)

je ne sais pas à quoi correspond le head off, c'est peut-etre pour justement supprimer les headers...

au passage, je programme en sh, et je ne fais pas du tout comme ça...
après, je sais que le sh est justement assez ouvert, mais pour extraire une valeur d'un count, je suis plutot du genre à faire

#!/bin/sh
var='echo "select count(*) from table;"|psql -U user pwd|grep '[0-9]'|grep -v row'
echo $var

attention, j'utilise 'qui s'obtient avec Alt Gr et 7
fonctionnement garanti en sh/postgres
0
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   6
 
Ok j'essaie cela alors.

Merci
0
dna.factory Messages postés 26003 Date d'inscription   Statut Modérateur Dernière intervention   1 618
 
attention... il faut évidement que tu modifie la partie psql par ton sqlplus, et l'affiche risquant d'etre différent, faudra modifier les greps (tu peux essayer de les remplacer par ton head off
0
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   6
 
Malheureusement sur la machine où je suis je n'ai pas psql je ne peux utiliser que sqlplus...
Merci pour ton aide quand même.
0
dna.factory Messages postés 26003 Date d'inscription   Statut Modérateur Dernière intervention   1 618
 
bah tu remplace la section psql par la section sqlplus user@SID/pwd
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   6
 
Salut,

Ma commande me renvoie ceci:

SQL*Plus: Release 10.2.0.5.0 - Production on Fri Oct 28 09:57:12 2011 Copyright (c) 1982, 2010, Oracle. All Rights Reserved. Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bit Production With the Partitioning, Data Mining and Real Application Testing options SQL> SQL> 18546 SQL> Disconnected from Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bit Production With the Partitioning, Data Mining and Real Application Testing options


18546 est le nombre que je souhaite récupérer.

Par avance merci
0
dna.factory Messages postés 26003 Date d'inscription   Statut Modérateur Dernière intervention   1 618
 
peux tu nous renvoyer le résultat en nous indiquant clairement les retours chariots ?

si il n'y en a pas, suffixe ta commande avec un
|awk -F "SQL>" '{print $3}'
si il y a des retours chariot, tu aura besoin de faire un grep pour ne récupérer que la ligne qui t'intéresse.
0
dna.factory Messages postés 26003 Date d'inscription   Statut Modérateur Dernière intervention   1 618
 
set head off rien
select count(*) as "fichier" from MATABLE ;
exit ;

???
Stop failing the turing test !
0
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   6
 
@dna.factory: la requête que tu me dis me renvoie exactment ce que je veux.
Le problème est que dans ma variable je met la connexion à la base et tout le reste d'où mon résultat que j'ai posté ci-dessus.

J'aimerai juste récupérer 18546 dans une variable que je pourrai utiliser par la suite dans mon script.

Merci.
0
remousse Messages postés 299 Date d'inscription   Statut Membre Dernière intervention   6
 
en ajoutant la ligne |awk -F "SQL>" '{print $3}' je récupère ma réponse comme je le souhaite avec un espace devant mais ça ce n'est pas grave je le retirerai.

Merci pour ton aide.
0
zipe31 Messages postés 36402 Date d'inscription   Statut Contributeur Dernière intervention   6 431
 
Suffit de le rajouter dans ton séparateur de champs...
awk -F "SQL> " '{print $3}
0