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 régulier
    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
    Points : 96
    Points
    96
    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 émérite
    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
    Points : 2 411
    Points
    2 411
    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 régulier
    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
    Points : 96
    Points
    96
    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 émérite 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
    Points : 2 566
    Points
    2 566
    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 : 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
    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 ?

  6. #6
    Membre régulier
    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
    Points : 96
    Points
    96
    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, 16h32
  2. Probleme de query SQL et XML
    Par byrong dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 10/10/2013, 18h48
  3. as400 sql/QUERY probleme de dates
    Par philswiss dans le forum Requêtes
    Réponses: 1
    Dernier message: 19/07/2007, 07h16
  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, 12h43
  5. probleme sql avec delphi
    Par lil_jam63 dans le forum Bases de données
    Réponses: 7
    Dernier message: 25/02/2004, 05h32

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