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 :

Lancer une requête SQL dans un script UNIX


Sujet :

Linux

  1. #1
    Membre confirmé
    Inscrit en
    Janvier 2009
    Messages
    168
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 168
    Par défaut Lancer une requête SQL dans un script UNIX
    Bonjour à tous,

    J'ai posé la même question ailleurs mais je pense m'avoir trompé sur le forum raison pour laquelle je repose ma question ici

    Je pars sur la principe que tout est possible en informatique.

    J'ai qq connaissances en SQL et en scrpit UNIX mais apparement pas suffisant pour résoudre mon problème.

    Il s'agit de lancer une requete de type

    insert into MaTable (colonne1, colonne2) Values ("val1", "val2")

    à partir d'un script shell unix.

    Ma base est sur MySQL

    Ce que je sais c'est que je dois certainement me connecter à la base à partir d'unix et je dois écrire le login et mot de passe.

    Vous pensez que c'est faisable tout ça ou que c'est trop demandé ?

    Merci de vos remarques

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 635
    Par défaut
    Bonjour wissen.ba,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql -h"$tonHost" -D"$taBase" -u"$tonId" -p"$tonPass" -e 'insert into MaTable (colonne1, colonne2) Values ("val1", "val2")'
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2009
    Messages
    168
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 168
    Par défaut
    Bonjour N_BaH et merci pour ta réponse

    J'ai essayé avec ce code dans un fichier test.sh

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    #!/bin/bash
    my_query='insert into MaTable (colonne1, colonne2) Values ("val1", "val2")'
    mysql -u mon_user -pmon_password ma_base -e "$my_query"
    mais après avoir executé la commande suivante sh test.sh

    j'ai eu ça comme message : test.sh [4]: mysql: introuvable

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 635
    Par défaut
    question idiote : mysql est installé sur ton système ?

    which mysql

    éventuellement, ajoute le chemin complet...

    PS: si tu lances ton script avec sh script.sh, c'est sh qui exécutera le script, et non bash...
    rend ton script exécutable : chmod u+x script.sh
    et tape : ./script.sh
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Membre Expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Par défaut
    ensuite si cela ne marche toujours pas, il faut vérifier que mysql est dans l'un des chemins contenu dans la variable d'environnement PATH

  6. #6
    Membre confirmé
    Inscrit en
    Janvier 2009
    Messages
    168
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 168
    Par défaut
    oulaa !! Ca se complique un peu pour moi.

    Si je vais doucement, j'ai tapé la commande

    et j'ai eu une série de répertoires précédée par

    which : 0652-141 Pas de mysql dans ... puis la liste des rep

    Donc je conclue que mysql n'est pas installé

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 635
    Par défaut
    regarde encore une fois avec whereis mysql
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  8. #8
    Membre Expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Par défaut
    pas obligatoirement, la variable PATH ne contient peu être pas le chemin vers mysql

    which va rechercher si mysql est présent dans l'un des répertoires présent dans la variable d'environnement PATH.

    Pour savoir si mysql est quelque part essaie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    find / -name "mysql"
    Si la commande te le retrouve, met à jour la variable PATH pour inclure le chemin contenant le répertoire ou est installé mysql. Sinon installe mysql.

  9. #9
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 801
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par wissem.ba Voir le message
    oulaa !! Ca se complique un peu pour moi.

    Si je vais doucement, j'ai tapé la commande

    et j'ai eu une série de répertoires précédée par

    which : 0652-141 Pas de mysql dans ... puis la liste des rep

    Donc je conclue que mysql n'est pas installé
    Ben action. Si t'es sur Fedora ou apparenté tu peux taper "yum update mysql" et si t'es sous Debian et apparenté, tu peux taper "aptitude search mysql" => t'auras plein de résultats => tu regardes le nom correspondant le mieux et tu tapes "aptitude install <ce nom>"

    Ou alors tu récupères le source que tu recompiles chez-toi.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. [KSH] envoie d'une requête SQL dans un script
    Par liegeus dans le forum Linux
    Réponses: 1
    Dernier message: 11/07/2011, 19h58
  2. exécuter une requète SQL dans un script
    Par jeanbernard.weck dans le forum VBScript
    Réponses: 0
    Dernier message: 14/06/2011, 10h16
  3. Lancer une requête SQL dans un script UNIX
    Par wissem.ba dans le forum Requêtes
    Réponses: 8
    Dernier message: 22/03/2010, 11h56
  4. Réponses: 7
    Dernier message: 31/08/2006, 18h03
  5. récupérer le résultat d'une requête sql dans un edit
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 3
    Dernier message: 28/07/2005, 14h07

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