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 :

Echec Requete en PHP - OK sous PhpMyAdmin [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 19
    Points : 8
    Points
    8
    Par défaut Echec Requete en PHP - OK sous PhpMyAdmin
    Bonjour sous PHP / MYSQL 5.0.45 j'obtiens l'erreur suivante:

    « Execution of a query to the database failed - You have an error in your SQL syntax;
    check the manual that corresponds to your MySQL server version for the right
    syntax to use near 'DISTINCT CAST(ntv.id AS CHAR) SEPARATOR "," ) AS tv_id, GROUP_CONCAT ( DISTINCT ' at line 1 »
    Ce que je ne comprends pas c'est que la même requete fonctionne sous PhpMyAdmin lorsque je teste le même ordre sql.


    Voici la requete:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    SELECT sc.id, sc.pagetitle, sc.longtitle, sc.description, sc.alias, sc.introtext, sc.menutitle, sc.content, sc.publishedon, 
    GROUP_CONCAT ( DISTINCT CAST(ntv.id AS CHAR) SEPARATOR "," ) AS tv_id, 
    GROUP_CONCAT ( DISTINCT ntv.value SEPARATOR ", " ) 
    AS tv_value 
    FROM `base1`.`mdx_site_content` sc 
    LEFT JOIN ( 
    SELECT DISTINCT tv.id, tv.value, tv.contentid FROM `base1`.`mdx_site_tmplvar_contentvalues` tv 
    WHERE ( ((tv.value LIKE '%school%')) ) ) 
    AS ntv ON sc.id = ntv.contentid 
    WHERE ( sc.id IN (63,64,65,66,67,68,69,70,71,72,73,97) AND sc.published=1 AND sc.searchable=1 AND sc.deleted=0 AND sc.type='document' 
    AND sc.privateweb=0 ) 
    GROUP BY sc.id 
    HAVING ( ( (sc.pagetitle LIKE '%school%') OR (sc.longtitle LIKE '%school%') OR (sc.description LIKE '%school%') 
    OR (sc.alias LIKE '%school%') OR (sc.introtext LIKE '%school%') OR (sc.menutitle LIKE '%school%') 
    OR (sc.content LIKE '%school%') OR (tv_value LIKE '%school%') ) ) 
    ORDER BY sc.publishedon,sc.pagetitle
    Merci pour votre aide.

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    essai en retirant l'espace entre la fonction group_concat et sa parenthese :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    GROUP_CONCAT(DISTINCT CAST(ntv.id AS CHAR) SEPARATOR "," ) AS tv_id,

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Bonjour

    TU lance cette requête vie mysql_query en php ? Peut-on avoir le code php correspondant ?
    Quand tu dis que tu as testé la requête sous PhpMyAdmin, c'est exactement la même requête (récupérée par un echo par exemple) ?

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 19
    Points : 8
    Points
    8
    Par défaut
    En retirant l'espace entre GROUP_CONCAT et la parenthese cela passe effectivement !!!! Merci. Cela faisait un moment que j'étais sur le problème.

    Maintenant quelle est l'explication ? Un bug de MYSQL ?

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

Discussions similaires

  1. [MySQL] Requete qui fonction sous PhpMyAdmin mais pas avec PHP
    Par lorentdups dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 09/09/2011, 21h35
  2. [Wamp] Requete fonctionne sous phpmyadmin mais pas en script php
    Par ben.IT dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 12
    Dernier message: 04/01/2010, 17h16
  3. [SQL] PB requête SQL dans un script php et sous phpmyadmin
    Par badboys46 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 22/06/2007, 12h36
  4. Réponses: 3
    Dernier message: 13/06/2007, 15h57
  5. [MySQL] réaliser une sous requete en php
    Par SENCABOY dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 14/02/2006, 21h19

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