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 :

[ADODB] erreur Query was empty


Sujet :

PHP & Base de données

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    423
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 423
    Points : 188
    Points
    188
    Par défaut [ADODB] erreur Query was empty
    Salut

    J'ai un problème avec ADOdb. pour chaque requête j'obtiens cette erreur :

    Query was empty
    Avec le mode debug activé j'obtiens :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Query: SET AUTOCOMMIT=0 failed. Query was empty
    1065: Query was empty
     
                         ADODB_mysqli._Execute(SET AUTOCOMMIT=0, false) % line  889, file: adodb.inc.php
                      ADODB_mysqli.Execute(SET AUTOCOMMIT=0) % line  153, file: adodb-mysqli.inc.php
                   ADODB_mysqli.BeginTrans() % line  752, file: adodb.inc.php
                ADODB_mysqli.StartTrans() % line   29, file: ShcMvLoginDao.class.php
             ShcMvLoginDao.checkIfUserExist(Array[3]) % line  141, file: ShcMvLogin.class.php
    Je ne comprends pas, sur mon serveur de test, en local, ça fonctionne parfaitement.

    EDIT :

    de plus, si j'exécute les requêtes directement (avec la fonction mysqli_query), il n'y a pas de problème.

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    423
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 423
    Points : 188
    Points
    188
    Par défaut
    Vraiment personne ?

    Je ne comprend franchement pas pourquoi ça ne fonctionne pas.

    Si j'essaie un script de ce genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <?php
    $connectionID = mysqli_init();
     
    mysqli_options($connectionID,5,0);
     
    $ok = mysqli_real_connect($connectionID, 'localhost', 'userName', 'motDePasse', 'dbName');
     
    $mysql_res =  mysqli_query($connectionID, 'SET AUTOCOMMIT=0');
    $mysql_res =  mysqli_query($connectionID, 'BEGIN');
    $mysql_res =  mysqli_query($connectionID, "SELECT COUNT(*) FROM utilisateurs");
    $mysql_res =  mysqli_query($connectionID, 'ROLLBACK');
    $mysql_res =  mysqli_query($connectionID, 'SET AUTOCOMMIT=1');
    ?>
    Je n'ai pas d'erreur

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    423
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 423
    Points : 188
    Points
    188
    Par défaut
    Je pense avoir trouvé. ADOdb passe un troisième paramètre à mysqli_query : MYSQLI_STORE_RESULT ou MYSQLI_USE_RESULT (MYSQLI_STORE_RESULT par défaut). Ce que je ne faisait pas dans mon script de test. Ce qui est étrange, c'est que quel que soit le paramètre que je passe ça ne va pas.

    $mysql_res = mysqli_query($connectionID, 'SET AUTOCOMMIT=0') -> fonctionne

    $mysql_res = mysqli_query($connectionID, 'SET AUTOCOMMIT=0', MYSQLI_USE_RESULT) -> ne fonctionne pas

    $mysql_res = mysqli_query($connectionID, 'SET AUTOCOMMIT=0', MYSQLI_STORE_RESULT) -> ne fonctionne pas

    pourtant le dernier devrait fonctionner aussi puisque si le 3e paramètre n'est pas indiqué, la fonction mysqli_query utilisera MYSQLI_STORE_RESULT


    le serveur posant problème fonctionne avec PHP 5.0.4 et utilise mysqli API version 4.1.20

    Le serveur ne posant pas problème (mon serveur de test) fonctionne sous PHP 5.1.6 et utilise :

    mysqli API library version 5.0.24a
    mysql API header version 5.0.22

Discussions similaires

  1. Erreur : Query was empty
    Par benjamin07 dans le forum Langage
    Réponses: 1
    Dernier message: 18/06/2012, 13h10
  2. [MySQL] Erreur aléatoire query was empty
    Par StephCdA dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 29/08/2011, 18h02
  3. [MySQL] Erreur : Query was empty(execution plusieurs requetes)
    Par fred619 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 09/05/2011, 00h06
  4. [MySQL] erreur : query was empty
    Par johan0510 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 09/03/2010, 15h32
  5. [PEAR][DB] Error "Query was empty"
    Par Katachana dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 21/01/2008, 15h51

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