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

Langage PHP Discussion :

Probleme sql query


Sujet :

Langage PHP

  1. #1
    Membre confirmé
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Par défaut Probleme sql query
    Bonjour,

    Je rencontre un problème lorsque je fais un appel à ma base.

    Voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $sqlQuery =
    		" SELECT ETABLISSEMENT_NAME, ETABLISSEMENT_URL_NAME, ETABLISSEMENT_TYPE_URL, ETABLISSEMENT_ID , ETABLISSEMENT_POSTAL , ETABLISSEMENT_ADRESSE , ETABLISSEMENT_VILLE " .
    		" FROM ETABLISSEMENT ".
    		" INNER JOIN ETABLISSEMENT_TYPE ON ETABLISSEMENT_TYPE.ETABLISSEMENT_TYPE_ID = ETABLISSEMENT_TYPEID ".
    		" WHERE ETABLISSEMENT_NAME LIKE '%$find%' OR ETABLISSEMENT_VILLE LIKE '%$find%' ".	
    		" ORDER BY ETABLISSEMENT_NAME ASC";
    		$req = mysql_query($sqlQuery);
    		checkSqlError($sqlQuery);
    		$nbreresultat=mysql_numrows($req);
    Il s'agit d'une page recherche. Quand je rajoute la ligne qui me permet de joindre deux tables la ligne WHERE ne prend plus en compte mon '%$find%'.

    Comment remedier à ce probleme ?

    Merci par avance,

    Aurélien

  2. #2
    Membre Expert
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Par défaut
    Salut,

    Peut-être suis-je à côté de la plaque mais bon...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ETABLISSEMENT_TYPE.ETABLISSEMENT_TYPE_ID = ETABLISSEMENT_TYPEID
    Peut-être ETABLISSEMENT_ID à la place ?

  3. #3
    Membre confirmé
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Par défaut
    Merci pour ta réponse.

    Hélas non il s'agit bien de ETABLISSEMENT_TYPEID.

    C'est assez bizarre car le code marchait bien avant que je joigne les 2 tables mais dès que je les ai jointe j'ai l'impression que ma condition WHERE n'a plus reconnu '%$find%'. Seulement j'ai besoin de joindre mes tables pour ma reecriture d'url

    En gros ça ça marche :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $sqlQuery =
    		" SELECT ETABLISSEMENT_NAME, ETABLISSEMENT_URL_NAME, ETABLISSEMENT_ID , ETABLISSEMENT_POSTAL , ETABLISSEMENT_ADRESSE , ETABLISSEMENT_VILLE " .
    		" FROM ETABLISSEMENT ".
    		" WHERE ETABLISSEMENT_NAME LIKE '%$find%' OR ETABLISSEMENT_VILLE LIKE '%$find%' ".	
    		" ORDER BY ETABLISSEMENT_NAME ASC";
    Et ça ça marche pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $sqlQuery =
    		" SELECT ETABLISSEMENT_NAME, ETABLISSEMENT_URL_NAME, ETABLISSEMENT_TYPE_URL, ETABLISSEMENT_ID , ETABLISSEMENT_POSTAL , ETABLISSEMENT_ADRESSE , ETABLISSEMENT_VILLE " .
    		" FROM ETABLISSEMENT ".
    		" INNER JOIN ETABLISSEMENT_TYPE ON ETABLISSEMENT_TYPE.ETABLISSEMENT_TYPE_ID = ETABLISSEMENT_TYPEID ".
    		" WHERE ETABLISSEMENT_NAME LIKE '%$find%' OR ETABLISSEMENT_VILLE LIKE '%$find%' ".	
    		" ORDER BY ETABLISSEMENT_NAME ASC";
    Et la je ne vois pas du tout comment faire.
    Peut-être joindre mes tables d'une autre manière ?
    Peut-être que le %$find% est recherché dans la deuxieme table ?
    Est ce qu'il ne faut pas fonctionner de cette maniere pour creer une page recherche ?

    Help !!!!

    Aurélien

  4. #4
    Membre Expert Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Par défaut
    Bonjour,

    sans doute une réponse bidon mais bon...

    as tu essayé de toujours préfixer tes champs par la table ?

    En gros, remplacer :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    " INNER JOIN ETABLISSEMENT_TYPE ON ETABLISSEMENT_TYPE.ETABLISSEMENT_TYPE_ID = ETABLISSEMENT_TYPEID ".

    par

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    " INNER JOIN ETABLISSEMENT_TYPE ON ETABLISSEMENT_TYPE.ETABLISSEMENT_TYPE_ID = ETABLISSEMENT.ETABLISSEMENT_TYPEID ".

    etc pour tous tes champs

  5. #5
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Question : si tu affiches tes requêtes et que tu les exécutes dans un client indépendant, genre phpMyAdmin, est-ce qu'elles fonctionnent ?
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  6. #6
    Membre confirmé
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Par défaut
    Merci pour les réponses.

    J'ai trouvé la solution.
    Pour ceux que ça pourrait intéresser voici la façon de procéder :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    " SELECT ETABLISSEMENT_NAME, ETABLISSEMENT_URL_NAME, ETABLISSEMENT_TYPE_URL, ETABLISSEMENT_ID , ETABLISSEMENT_POSTAL , ETABLISSEMENT_ADRESSE , ETABLISSEMENT_VILLE " .
    		" FROM ETABLISSEMENT ".
    		" LEFT JOIN ETABLISSEMENT_TYPE ON ETABLISSEMENT_TYPE_ID=ETABLISSEMENT_TYPEID".
    		" WHERE ETABLISSEMENT_NAME LIKE '%$find%' OR ETABLISSEMENT_VILLE LIKE '%$find%' ".	
    		" ORDER BY ETABLISSEMENT_NAME ASC";
    Aurélien

Discussions similaires

  1. Probleme SQL Query
    Par Seth77 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 01/06/2015, 15h32
  2. Probleme de query SQL et XML
    Par byrong dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 10/10/2013, 17h48
  3. as400 sql/QUERY probleme de dates
    Par philswiss dans le forum Requêtes
    Réponses: 1
    Dernier message: 19/07/2007, 06h16
  4. Recherche Data pour m'exercer en SQL-Query
    Par Oneill dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 13/10/2004, 11h43
  5. probleme sql avec delphi
    Par lil_jam63 dans le forum Bases de données
    Réponses: 7
    Dernier message: 25/02/2004, 04h32

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