variable

Eléphant du PHP | 440 Messages

24 déc. 2006, 21:23

Bonjour,

je voudrais inclure une variable qui récupèrerait la valeur id dans ma base mysql.
Est-ce que ce code est bon ?
<?php 
    $table = "organismes"; 
    $sql = "SELECT * FROM " . $table." order by SOCIETE"; 
    $res = mysql_query($sql); 
	$nb = mysql_num_rows($res);
    $i = 0; 
	   while ($i < $nb)
	   {
...etc
Apparemment pas ! L'idée est qu'à partir d'une adresse page.php?id=xxx on arrive quelque part.

Merci.
Débutant complet en php/mysql. Merci pour votre aide.

Eléphant du PHP | 440 Messages

24 déc. 2006, 21:24

<?php 
    $table = "organismes"; 
    $sql = "SELECT * FROM " . $table." order by SOCIETE"; 
    $res = mysql_query($sql); 
    $id=mysql_result($res, $i, "id");
    $nb = mysql_num_rows($res);
    $i = 0; 
	   while ($i < $nb){ ...
Pardon. Voici le "bon" code.
Débutant complet en php/mysql. Merci pour votre aide.

Avatar du membre
ViPHP
ViPHP | 3008 Messages

25 déc. 2006, 01:54

Pour faire ce que tu désires, il te faut passer ta variable dans la clause WHERE de ta requête.
$sql = "SELECT * FROM " . $table." order by SOCIETE WHERE id=".$_GET['ton_champ']; 

Administrateur PHPfrance
Administrateur PHPfrance | 11457 Messages

25 déc. 2006, 10:26

Rappel :
Sauf cas de force majeure, le SELECT * est à proscrire.
Il est préférable de définir les champs souhaités.

Eléphant du PHP | 440 Messages

25 déc. 2006, 19:44

Voici ce que devient le début de mon code :
<?php 
    $table = "organismes"; 
	$sql = "SELECT * FROM " . $table." order by SOCIETE WHERE id=".$_GET['REF']; 
    $res = mysql_query($sql); 
	$nb = mysql_num_rows($res);
    $i = 0; 
	   while ($i < $nb)
	   { 
	   echo '<fo....
J'ai toujours un message d'erreur. Semble-t-il lié à la ligne : $nb = mysql_num_rows($res);
Débutant complet en php/mysql. Merci pour votre aide.

Modérateur PHPfrance
Modérateur PHPfrance | 7636 Messages

25 déc. 2006, 19:46

J'ai toujours un message d'erreur. Semble-t-il lié à la ligne : $nb = mysql_num_rows($res);
Et c'est un secret professionnel ou on peut le voir ce message ? :roll:

/!\ Avant de poster se documenter et rechercher.
Qui ne sait pas rendre un service n'a pas le droit d'en demander.
MaBrute

Eléphant du PHP | 440 Messages

25 déc. 2006, 19:47

Le voici :
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in /mnt/115/free.fr/d/6/europoleformations/formation/fiches/fiche_OF.php on line 57
Débutant complet en php/mysql. Merci pour votre aide.

Modérateur PHPfrance
Modérateur PHPfrance | 7636 Messages

25 déc. 2006, 19:55

Hi hi... en fait je m'en doutais :P

Bon regarde ce post pour aider à trouver un "vrai" message d'erreur.

Indice... remet la requête dans l'ordre (order by... il est bien là ? :wink: )

/!\ Avant de poster se documenter et rechercher.
Qui ne sait pas rendre un service n'a pas le droit d'en demander.
MaBrute

Eléphant du PHP | 440 Messages

25 déc. 2006, 20:01

le post ne m'aide pas beaucoup. débutant voulant dire qu'on n'y connaît et comprend rien, je ne fait que bidouiller le code sans y comprendre grand chose !

Donc apparemment il y a un problème d'ordre dans les éléments de mon code. Peux-tu être plus précis ? Je t'en remercie.
Débutant complet en php/mysql. Merci pour votre aide.

Eléphant du PHP | 440 Messages

25 déc. 2006, 20:09

le post ne m'aide pas beaucoup. débutant voulant dire qu'on n'y connaît et comprend rien, je ne fait que bidouiller le code sans y comprendre grand chose !

Donc apparemment il y a un problème d'ordre dans les éléments de mon code. Peux-tu être plus précis ? Je t'en remercie.
Débutant complet en php/mysql. Merci pour votre aide.

Modérateur PHPfrance
Modérateur PHPfrance | 7636 Messages

25 déc. 2006, 20:11

le post ne m'aide pas beaucoup.
Et tu l'as lu et compri en 5 min ? :roll:
débutant voulant dire qu'on n'y connaît et comprend rien, je ne fait que bidouiller le code sans y comprendre grand chose !
ça ne veut pas non plus dire qu'on ne doit pas se donner un peu de mal.

Bon tu connais les requêtes :
1. Selection => SELECT
2. Table => FROM
3. Restriction => WHERE
(4. Goupement => GROUP BY)
5. Tri => ORDER BY
:wink:

/!\ Avant de poster se documenter et rechercher.
Qui ne sait pas rendre un service n'a pas le droit d'en demander.
MaBrute

Eléphant du PHP | 440 Messages

25 déc. 2006, 20:40

$sql = "SELECT * FROM " . $table." order by id=".$_GET['REF'] WHERE SOCIETE" ; 
si c'est un problème d'ordre, à part inverser, je vois pas !
Débutant complet en php/mysql. Merci pour votre aide.

Avatar du membre
ViPHP
ViPHP | 3008 Messages

25 déc. 2006, 20:51

$sql = "SELECT * FROM " . $table." order by id=".$_GET['REF'] WHERE SOCIETE" ; 
si c'est un problème d'ordre, à part inverser, je vois pas !
Tu es débutant alors il faut y aller pas à pas. Regardes déjà les tutos sur les concaténations, tu n'es pas au point dessus.

Aides toi de la coloration syntaxique, tu devrais repérer immédiatement ton erreur.

Eléphant du PHP | 440 Messages

25 déc. 2006, 21:04

Après des essais, je suis finalement revenu à ce code :
<?php 
    $table = "organismes"; 
	$sql = "SELECT * FROM " . $table." order by SOCIETE where REF=".$_GET['REF']; 
    $res = mysql_query($sql); 
	$nb = mysql_num_rows($res);
    $i = 0; 
	   while ($i < $nb)
	   { 
	   echo '<font face="Arial, Helvetica, sans-serif" size="2" color="#FF9900"><b>'.mysql_result($res, $i, "SOCIETE").'</b></font>'; 
	   '<font face="Arial, Helvetica, sans-serif" size="1" color="#666666"> ('.mysql_result($res, $i, "REF").')</font><br />'; 
la couleur ne m'aide pas beaucoup puisque je ne sais pas ce que signifient les couleurs.
Où y a-t-il une concaténation ?
Débutant complet en php/mysql. Merci pour votre aide.

Eléphant du PHP | 86 Messages

25 déc. 2006, 21:21

regarde bien les post au dessus et regarde ta requete tu devrais trouvé ton erreur. ;)


PS: je suis debutant aussi mais il faut savoir lire les post en entier ;) et avoir un minimum de dissernement