Rechercher : dans
Par :

Script en shell avec requette sql

Dernière réponse le 20 jui 2009 à 16:27:31 nbonnet, le 13 jui 2009 à 09:20:45 
 Signaler ce message aux modérateurs

Bonjour,

Je ne sais pas si c'est le bon forum mais je tente quand même.

Je voudrais créer un script qui m'affiche le résulat de ma requette sql. Ma question est simple :

omment en shell je peux récupérer les données que renvoi ma requette (sachant qu'elle renvoie 2 colonnes avec X lignes)?

Mes recherches m'ont permis de trouver comment l'executer mais pas de récupérer les valeurs.

Est-ce qu'il suffit de faire :

MaVar='sql -S serveur -D base -U utilisateur -P mot_de_passe -b Base <requetes.sql'


Merci d'avance ---------------------------------------------------------------------
La vie est-elle trop courte pour rester derrière son écran?

Configuration: Mac OS X
Firefox 3.0.11

1

dubcek, le 13 jui 2009 à 09:39:08

Hello
avec quel shell ?
essayer :
MaVar=$(sql -S serveur -D base -U utilisateur -P mot_de_passe -b Base <requetes.sql)

Répondre à dubcek

2

nbonnet, le 13 jui 2009 à 14:00:26

Slt c'est du bash.
------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

3

dubcek, le 13 jui 2009 à 14:33:34

Donc essayer MaVar=$(sql -S serveur -D base -U utilisateur -P mot_de_passe -b Base <requetes.sql)

Répondre à dubcek

4

nbonnet, le 13 jui 2009 à 17:16:00

Oki alors la réponse est qu'il ne connait pas la commande sql j'ai recherché sur le net je ne trouve pas comment faire.

je precise que je suis sur mac, j'ai installé MAMP et que le reste du script se lance bien. ------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

5

dubcek, le 13 jui 2009 à 17:43:05

Ca veut dire que sql n'est pas dans le PATH, pour vérifier echo $PATH
essayer /chemin/sql ...

Répondre à dubcek

6

nbonnet, le 15 jui 2009 à 15:44:39

Voila ce que "echo $PATH" me renvoie :

/Library/Frameworks/Python.framework/Versions/Current/bin:/bin:/sbin:/usr/bin:/usr/local/bin:/usr/sbin

Je ne trouve pas lequel choisir il me retourne a chaque fois :

No such file or directory.

Vraiment dsl je suis vraiment debutant. En tout cas merci de m'aider
---------------------------------------------------------------------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

7

dubcek, le 15 jui 2009 à 15:54:11

Il faut savoir où est installé l'exécutable sql
y a-t-il une variable d'environnement ? set ¦ grep -i sql
sinon le chercher
find / -type f -name sql -ls

Répondre à dubcek

8

nbonnet, le 15 jui 2009 à 16:23:22

Apparemment il n'y a pas de variable d'environnement et le find me le trouve pas.

auto115:~ nbonnet$ set | grep -i sql
auto115:~ nbonnet$ find / -type f -name sql -ls
find: /.fseventsd: Permission denied
find: /.Spotlight-V100/Store-V1: Permission denied
find: /dev/fd/3: Not a directory
find: /dev/fd/4: Not a directory
find: /Library/Application Support/Apple/ParentalControls/Users: Permission denied
find: /Library/Application Support/Apple/Remote Desktop/Client: Permission denied
find: /Library/Application Support/Apple/Remote Desktop/Task Server: Permission denied
find: /Library/Application Support/Lobotomo Software/IPSecuritas: Permission denied
find: /Library/Application Support/VPN Tracker 4/cert: Permission denied
find: /Library/Caches/com.google.MacFUSEAutoinstaller.Keystone.0: Permission denied
find: /Library/Caches/com.google.UpdateEngine.Framework.0: Permission denied
find: /Library/Logs/Console/501: Permission denied
find: /Library/PreferencePanes/Sybase.prefPane: Permission denied
find: /net/localhost: Operation timed out
find: /net/broadcasthost: Operation timed out

et ceci n'en fini plus
puis
------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

9

dubcek, le 15 jui 2009 à 16:27:49

Sql est bien installé ?
essaye
find /usr -type f -name sql -ls

Répondre à dubcek

10

nbonnet, le 15 jui 2009 à 16:31:54

J'ai installé MAMP et la commande ne me retourne aucun resultat. ------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

11

dubcek, le 15 jui 2009 à 16:36:18

Est ce qu'il y a un dossier MAMP ?

Répondre à dubcek

12

nbonnet, le 15 jui 2009 à 16:39:12

Oui il est dans /Applications/MAMP/

Il faut que je lance la commande depuis ce répertoire? ------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

13

nbonnet, le 15 jui 2009 à 16:51:13

J'ai regardé aux alentours il y a un script pour le démarrage du service MySql qui commence par

/Applications/MAMP/Library/bin/mysqld_safe

sauf que lorsque je met ceci dans mon script j'ai en retour

chown: /Applications/MAMP/db/mysql/auto115.intra.err: Operation not permitted

je vois pas quelle est l'erreur j'ai tenté de mettre le chown sur nbonnet:nbonnet car il était sur nbonnet:admin mais ca marche toujours pas ------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

14

dubcek, le 15 jui 2009 à 17:04:53

Essaye
ls /Applications/MAMP/Library/bin
ou ne serait-ce pas mysql ?
ou find /Applications/MAMP -name mysql -ls

Répondre à dubcek

15

nbonnet, le 15 jui 2009 à 17:31:59

Il ne me trouve pas non plus mais j'ai trouver en utilisant

/Applications/MAMP/Library/bin/mysqladmin --host=127.0.0.1 --user=nbonnet --port=8889

au lieu de

sql

dans le script cela ne me retourne plus d'erreur sauf qu'il faut que je trouve pas les bonnes options pour me connecter à la base de donnée. ------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

16

nbonnet, le 17 jui 2009 à 15:40:15

Enfin la solution

printf "SELECT login, nombre FROM adsl"|/Applications/MAMP/Library/bin/mysql -D test_bagotage>test.text

voila la ligne qu'il me faut pour pouvoir reupérer les données de ma table mais dans un fichier text. Il me reste plus qu'a travailler sur ce fichier pour pour utiliser les données ---------------------------------------------------------------------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

17

dubcek, le 17 jui 2009 à 15:52:07

Il faut ajouter /Applications/MAMP/Library/bin dans ton PATH pour appeler simplement mysql:
export PATH=$PATH:/Applications/MAMP/Library/bin
ajouter cette ligne à la fin de .bashrc pour que se soit permanent

Répondre à dubcek

18

nbonnet, le 20 jui 2009 à 15:01:01

Oki merci bien j'ai réussi a me connecter a ma base de donnée et à lancer ma requete. sauf que cette dernière me renvoie un fichier comme ceci :

CLnom STnom ADippublic ADlogin
Scipt equation 10.11.12.13 login
CLnom STnom ADippublic ADlogin
Scipt2 equation2 10.11.12.13 login

J'aimerais bien suprimer les lignes :
CLnom STnom ADippublic ADlogin

je n'arrive pas a faire ma boucle avec un while. Tu peux m'aider pour ceci?

------------------------------------------------------------­---------
La vie est-elle trop courte pour rester derrière son écran?

Répondre à nbonnet

19

dubcek, le 20 jui 2009 à 15:32:09

Soit depuis un fichier
sed -e '/CLnom STnom ADippublic ADlogin/d' < fichier
soit depuis un pipe line
ta_commande ¦ sed -e '/CLnom STnom ADippublic ADlogin/d'

Répondre à dubcek