Requête sql sous php

Requête sql sous php - PHP - Programmation

Marsh Posté le 22-08-2006 à 14:12:26    

Je tente d'effectuer la requête suivante:
 

Code :
  1. for($i = 0; $i <= ($indice); $i++) {
  2. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` = '.'$rub_niv1[$indice]-> rub_id';
  3. }


 
Mon navigateur me retourne une erreur de syntaxe près de '[$indice]-> rub_id'.
En fait, $rub_niv1[] est un tableau contenant des instances d'une classe. Je rentre donc un indice dans ce tableau et accède à la propriété 'rub_id' pour la comparer avec 'id_parent' de la bdd.
 
Si vous pouviez m'éclairer sur l'erreur que j'ai commis, ça me débloquerait.
 
Merci ;)

Reply

Marsh Posté le 22-08-2006 à 14:12:26   

Reply

Marsh Posté le 22-08-2006 à 14:34:18    

Code :
  1. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` = '.$rub_niv1[$indice]-> rub_id;

Message cité 1 fois
Message édité par jbourdellon le 22-08-2006 à 14:34:48
Reply

Marsh Posté le 22-08-2006 à 14:34:58    

et si tu enlevais les guillemets ?

Code :
  1. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` = '.$rub_niv1[$indice]->rub_id;


et quel est l'interet de la boucle ??

Reply

Marsh Posté le 22-08-2006 à 14:52:26    

jbourdellon a écrit :

Code :
  1. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` = '.$rub_niv1[$indice]-> rub_id;



J'avais en effet utilisé cette syntaxe, mais il m'indique une erreur similaire:
Erreur de syntaxe près de ''
C'est d'ailleurs pour cela que je ne comprenais, car ma syntaxe semblait correcte :sweat:

Reply

Marsh Posté le 22-08-2006 à 14:58:24    

soju a écrit :

et si tu enlevais les guillemets ?

Code :
  1. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` = '.$rub_niv1[$indice]->rub_id;


et quel est l'interet de la boucle ??


J'ai pas mis tout le code ^^
 

Code :
  1. for($i = 0; $i <= $indice; $i++) {
  2. $sql = 'SELECT `id_rub`,`titre`  FROM `rubriques` WHERE `id_parent` ='.$rub_niv1[$indice]-> rub_id;
  3. $req = mysql_query($sql) or die('Erreur SQL 2 !<br>'.$sql.'<br>'.mysql_error());
  4. $jindice=0;
  5. while ($data = mysql_fetch_assoc($req)) {
  6. $name = $data['titre'];
  7. $id = $data['id_rub'];
  8. $link = $url.$data['id_rub'];
  9. $rub_niv1[$indice].add_child($jindice,new Rubrique($name,$link,$id));
  10. $jindice++;
  11. }
  12. }

Reply

Marsh Posté le 22-08-2006 à 14:59:06    

espace entre $rub_niv1[$indice]-> et rub_id;

Reply

Marsh Posté le 22-08-2006 à 17:25:24    

skeye a écrit :

espace entre $rub_niv1[$indice]-> et rub_id;


Ca n'a pas d'incidence ;)

Reply

Marsh Posté le 22-08-2006 à 17:46:39    

donne voir le format de ton $rub_niv1 ?

Reply

Marsh Posté le 22-08-2006 à 21:07:46    

Si id_parent est de type texte et pas un numérique c'est peut être normal et il manquerait juste des " :)

Reply

Marsh Posté le 22-08-2006 à 22:15:11    

ne serait-ce pas mieux de faire une seule requête et de récupérer tous les résultats dans une boucle, plutôt que de faire X requêtes ?
 
regarde du côté de la syntaxe

Code :
  1. SELECT id_rub,titre FROM rubriques WHERE id_parent IN (valeur1, valeur2, valeur3, ...);

Reply

Marsh Posté le 22-08-2006 à 22:15:11   

Reply

Marsh Posté le 22-08-2006 à 22:36:29    

couak a écrit :

ne serait-ce pas mieux de faire une seule requête et de récupérer tous les résultats dans une boucle, plutôt que de faire X requêtes ?
 
regarde du côté de la syntaxe

Code :
  1. SELECT id_rub,titre FROM rubriques WHERE id_parent IN (valeur1, valeur2, valeur3, ...);



Même un BETWEEN si mysql :)

Reply

Marsh Posté le 23-08-2006 à 09:22:45    

jbourdellon a écrit :

donne voir le format de ton $rub_niv1 ?


 

Code :
  1. class Rubrique
  2. {
  3. var $rub_name = "";
  4. var $rub_link = "";
  5. var $rub_id = 0;
  6. var $nb_children = 0;
  7. var $tab_children = Array();
  8. function Rubrique( $name, $link, $id )
  9. {
  10.  $this->rub_name = $name;
  11.  $this->rub_link = $link;
  12.  $this->rub_id = $id;
  13. }
  14. function add_child( $indice, $new_child )
  15. {
  16.  $this->tab_children[$indice] = $new_child;
  17.  $this->nb_children ++;
  18. }
  19. function __clone () {
  20.  $this->rub_name = $that->rub_name ;
  21.  $this->rub_link = $that->rub_link;
  22.  $this->rub_id = $that->rub_id;
  23.  $this->nb_children = $that->rub_id;
  24.  $this->tab_children = $that->tab_children;
  25. }
  26. }


 

couak a écrit :

ne serait-ce pas mieux de faire une seule requête et de récupérer tous les résultats dans une boucle, plutôt que de faire X requêtes ?
 
regarde du côté de la syntaxe

Code :
  1. SELECT id_rub,titre FROM rubriques WHERE id_parent IN (valeur1, valeur2, valeur3, ...);



Le problème étant que je réalise justement X requêtes, parceque chaque résultat renvoie des données qui doivent être attribuées à une rubrique précise ;)
Du coup, même le IN et BETWEEN ne pourront être utilisés, puisque la requête ne concerne qu'une valeur précise à la fois de id_parent.


Message édité par Balflear le 23-08-2006 à 09:37:43
Reply

Sujets relatifs:

Leave a Replay

Make sure you enter the(*)required information where indicate.HTML code is not allowed