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

PHP & Base de données Discussion :

PDO SQL : lire une @variable SQL d'une transaction [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 44
    Par défaut PDO SQL : lire une @variable SQL d'une transaction
    Bonjour.

    J'exécute via php un ensemble de requêtes SQL dans le cadre d'une transaction.
    Dans cette transaction, une valeur est affectée à une variable.
    Je veux récupérer en PHP à l'issue de l'exécution le contenu de cette variable.
    Je termine donc la transaction par un SELECT sur la variable concernée afin que la transaction renvoie le contenu de la variable.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    START TRANSACTION;
     
    ....
     
    SET @MAVARIABLE := ... ;
     
    ...
     
    SELECT @MAVARIABLE;
     
    COMMIT;
    Exécutée directement dans une interface mysql, la transaction marche parfaitement et me renvoie en résultat la valeur numérique contenue dans la variable.

    En php/pdo (->prepare() ->execute()..), je n'arrive pas à récupérer cette variable. (tenté un fetch fetchAll, rien en résultat en sortie (array vide)).

    Une indication sur la façon de procéder ?

    D'avance, merci.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Les transactions en PDO ca se fait avec beginTransaction() et commit(), c'est bien ce que tu fais ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 44
    Par défaut
    Désolé si ce n'est pas dans les règles de l'art, c'est la première fois que j'utilise les transactions.

    Je n'ai pas procédé tel indiqué.

    Je fais :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $requete = "START TRANSACTION;
     ....
     SET @MAVARIABLE := ... ;
     ...
     SELECT @MAVARIABLE;
     COMMIT; "
     
    $parametres= array(
    'a'=> $valeur,...
    );
    $sql =$base->prepare($requete);
    $sql->execute($parametres);

    Tous les INSERT, SELECT... inclus dans la transaction s'exécutent bien, la table est bien mise à jour.

    Je vais essayer avec ta méthode afin de voir si cela dhange quelquechose à mon problème, je reviendrais cloturer ou signaler s'il y a encore un problème.

    Merci pour m'avoir aiguillé

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

Discussions similaires

  1. [MySql]Insérer une variable "string" dans une requête SQL
    Par Saten dans le forum Windows Forms
    Réponses: 9
    Dernier message: 13/10/2008, 17h39
  2. [SQL] insérer des variables php dans une requête sql
    Par lili38 dans le forum PHP & Base de données
    Réponses: 28
    Dernier message: 22/06/2007, 16h38
  3. [SQL] Comment insérer une variable php dans une requête SQL ?
    Par Yagami_Raito dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 14/05/2007, 08h47
  4. Appeler une variable VB dans une requête SQL
    Par Chopper dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 12/09/2006, 14h27
  5. Réponses: 2
    Dernier message: 28/06/2006, 15h56

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