Condition PHP

Résolu/Fermé
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 - 21 févr. 2011 à 09:07
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 - 23 févr. 2011 à 23:39
Bonjour,

Voilà je bloque sur une condition, si quelqu'un peux me donner une explication ?
Merci beaucoup de votre aide.

Mon script affiche dans un tableau les noms des utilisateurs qui jouent de la trompette ça c'est bon.
Mais je souhaiterai lorsqu'on a pas d'utilisateurs qui jouent de cet instrument la ligne TH (Trompette) ne s'affiche pas.
Je ne sais pas si c'est clair pour vous ce n'ai pas facile à expliquer.
Merci vraiment de votre aide.

<table style="width:25%; float:left"> 
	<tr>
		<td class="table-separateur">
<table width="100%" border="2" cellspacing="1" cellpadding="5">
	<tr>
		<td class="table-entete">DEBUTANT</td>
<?php
	echo'<tr>';
		echo'<th width="25%" class="table-sous-entete">Trompette</th>'; 
	echo'</tr>';
$resultats = $bdd->query	("SELECT *
							FROM utilisateur	
							WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant'
							AND 'utilisateur'.'pupitre_utilisateur' = 'Trompette'
							ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);
while ($donnees = $resultats->fetch())
{	
?>	
		<td width="25%" class="table-ligne1"><?php echo $donnees->nom_utilisateur . ' ' . $donnees->prenom_utilisateur; ?></td>	
	</tr>
<?php
}
?>
</table>
		</td>
	</tr>
</table>


A voir également:

21 réponses

Utilisateur anonyme
21 févr. 2011 à 09:45
Bonjour,

Je ferais quelques chose comme ça :

<table style="width:25%; float:left">
<tr>
<td class="table-separateur">
<table width="100%" border="2" cellspacing="1" cellpadding="5">
<tr>
<td class="table-entete">DEBUTANT</td>
<?php

$resultats = $bdd->query ("SELECT *
FROM utilisateur
WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant'
AND 'utilisateur'.'pupitre_utilisateur' = 'Trompette'
ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);
if (mysql_numrows($resultat)>0) {
echo'<tr>';
echo'<th width="25%" class="table-sous-entete">Trompette</th>';
echo'</tr>';

while ($donnees = $resultats->fetch())
{
?>
<td width="25%" class="table-ligne1"><?php echo $donnees->nom_utilisateur . ' ' . $donnees->prenom_utilisateur; ?></td>
</tr>
<?php
}
}
?>
</table>
</td>
</tr>
</table>

On affiche le TH si la requête rend des lignes pour la requête grace à mysql_numrows

Cordialement
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
21 févr. 2011 à 16:18
Bonjour et merci de votre aide.

Voilà l'erreur que ça met si vous pouvez encore m'aider merci beaucoup.

Fatal error: Call to a member function setFetchMode() on a non-object in E:\wamp\www\cliquedecruet\page\musicien_debutant.php on line 14
0
chico200987 Messages postés 791 Date d'inscription mardi 6 avril 2004 Statut Membre Dernière intervention 30 juillet 2018 143
21 févr. 2011 à 17:30
Salut,

Essaie d'afficher les erreurs en mettant juste apres ta connection :

$bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);


Et rajoute un S a $resultat ligne 15 du code de internetwebservice

Pour donner : "if (mysql_numrows($resultats)>0) {"
0
Utilisateur anonyme
21 févr. 2011 à 17:43
Oui effetivement il manque un s à resultats mais le pb n'est pas là.
Avant le code que vous présentez là, avez fait une connection mysql ?

Mysql_connect('localhost',$user,$password);

https://www.php.net/manual/fr/function.mysql-connect.php

Puis un Mysql_select_db($base);

?
0
Utilisateur anonyme
21 févr. 2011 à 17:45
Pardon un

$bdd = new PDO($dsn,$user,$pass,$options);

https://www.php.net/manual/fr/pdo.query.php
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
21 févr. 2011 à 18:33
bonjour et merci de votre aide à tous

Pour vous dire j'avais rajouté le s à $resultats.

Ensuite pour ma connexion c'est tout en ordre, je ne l'ai simplement pas mis ici.

Mais ma connexion fonctionne bien.

Si vous pouvez encore m'aider, merci

Fatal error: Call to a member function setFetchMode() on a non-object in E:\wamp\www\cliquedecruet\page\musicien_debutant.php on line 14
0
bah chez moi c'est mysql_num_rows, pas mysql_numrows
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
21 févr. 2011 à 19:21
Je vous renvoie mon script et mon erreur
Merci

<table style="width:25%; float:left"> 
	<tr>
		<td class="table-separateur">
<table width="100%" border="2" cellspacing="1" cellpadding="5">
	<tr>
		<td class="table-entete">DEBUTANT</td>
	</tr>
<?php
$resultats = $bdd->query ("SELECT * FROM utilisateur WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant' AND 'utilisateur'.'pupitre_utilisateur' = 'Trompette' ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);
	if (mysql_num_rows($resultats)>0) {
		echo'<tr>';
		echo'<th width="25%" class="table-sous-entete">Trompette</th>';
		echo'</tr>';

		while ($donnees = $resultats->fetch()){
?>
	<td width="25%" class="table-ligne1"><?php echo $donnees->nom_utilisateur . ' ' . $donnees->prenom_utilisateur; ?></td>
</tr>
<?php
		}
	}
?> 
</table>
		</td>
	</tr>
</table>
0
chico200987 Messages postés 791 Date d'inscription mardi 6 avril 2004 Statut Membre Dernière intervention 30 juillet 2018 143
22 févr. 2011 à 12:13
Pourrais-tu juste rajouter le
$bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); que j'ai demande pour avoir plus d'infos sur l'erreur ?
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
22 févr. 2011 à 13:50
Il faut remplacer ce code
while ($donnees = $resultats->fetch()) 
{	
?>	
<td width="25%" class="table-ligne1"><?php echo $donnees->nom_utilisateur . ' ' . $donnees->prenom_utilisateur; ?></td>	
</tr> 

par
while ($donnees = $resultats->fetch()) 
          {	echo'<tr><td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td></tr>';
}
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
22 févr. 2011 à 14:30
Bonjour et merci de votre aide

Malheureusement cela n'affiche pas le titre "Trompette" mais par contre ça affiche bien les utilisateurs.
Je vous redonne mon script complet avec vos modifs si vous pouvez encore m'aider.
Je vous remercie beaucoup

Voilà l'erreur
Warning: mysql_num_rows() expects parameter 1 to be resource, object given in E:\wamp\www\cliquedecruet\page\musicien_debutant.php on line 16


<table style="width:25%; float:left"> 
	<tr>
		<td class="table-separateur">
<table width="100%" border="2" cellspacing="1" cellpadding="5">
	<tr>
		<td class="table-entete">DEBUTANT</td>
	</tr>
<?php
$resultats = $bdd->query	("SELECT *
							FROM utilisateur	
							WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant'
							AND 'utilisateur'.'pupitre_utilisateur' = 'Tromptte'
							ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);
if (mysql_num_rows($resultats)>0) { 
	echo'<tr>';
		echo'<th width="25%" class="table-sous-entete">Tromptte</th>'; 
	echo'</tr>';
}
while ($donnees = $resultats->fetch()) 
{	echo'<tr>
			<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>
		</tr>';
}
?>
</table>
		</td>
	</tr>
</table>
0
Utilisateur anonyme
22 févr. 2011 à 14:57
Désolé, je n'avais pas vu que vous utilisez PDO...
mysql_rowcount ne marche pas avec
il y a $resultats->rowCount(), mais ça ne fonctionne pas avec toutes les bases, je ne sais pas pour MySQL
0
Utilisateur anonyme
22 févr. 2011 à 15:00
mettez ça à la place

$booEntete = false;
while ($donnees = $resultats->fetch())
{
if (!$booEntete) {
echo'<tr>';
echo'<th width="25%" class="table-sous-entete">Tromptte</th>';
echo'</tr>';
$booEntete=true;
}
echo'<tr>
<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>
</tr>';
}
?>

de ça

if (mysql_num_rows($resultats)>0) {
echo'<tr>';
echo'<th width="25%" class="table-sous-entete">Tromptte</th>';
echo'</tr>';
}
while ($donnees = $resultats->fetch())
{ echo'<tr>
<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>
</tr>';
}
?>
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
22 févr. 2011 à 15:05
essai d'insérer ce code avant
if (mysql_num_rows($resultats)>0) { 

$sql = "SELECT COUNT(*) AS nb FROM utilisateur where 'utilisateur'.'membre_utilisateur' = 'Debutant'
AND 'utilisateur'.'pupitre_utilisateur' = 'Tromptte' ";
    $result = $bdd->query($sql);

    $nb = $columns['nb'];

puis remplacer
<code>if (mysql_num_rows($resultats)>0) { 
</code> par
if($nb>0){

En fait le problème provient du mixage entre le code php4 et php5
Tu peux chercher une fonction qui retourne le nombre d'enregistrements d'une requête.
tito
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
22 févr. 2011 à 19:54
Merci de votre aide mais malheureusement je suis toujours en train de me prendre la tête alors si vous avez de nouveau le temps de m'aider?
Merci beaucoup

Ma connexion à ma BDD est en PHP5, j'ai essayé votre script mais l'erreur est...

Notice: Undefined variable: columns in E:\wamp\www\cliquedecruet\page\musicien_debutant.php on line 15

<?php
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where 'utilisateur'.'membre_utilisateur' = 'Debutant'
AND 'utilisateur'.'pupitre_utilisateur' = 'Tromptte' ";
    $result = $bdd->query($sql);

    $nb = $columns['nb'];

    if($nb>0){
	echo'<tr>';
		echo'<th width="25%" class="table-sous-entete">Tambour</th>'; 
	echo'</tr>';
}
while ($donnees = $resultats->fetch()){	
	echo'<tr>';
		echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>';
	echo'</tr>';
}
?>
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
22 févr. 2011 à 20:56
essai d'insérer ceci
$columns = $result->fetch();
avant
 $nb = $columns['nb'];

j'ai oublié cette ligne.
tito
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
22 févr. 2011 à 21:30
donc j'ai fait comme vous me l'avez dit
mais j'ai toujour une erreur

Fatal error: Call to a member function fetch() on a non-object in E:\wamp\www\cliquedecruet\page\musicien_debutant.php on line 14

<?php
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where 'utilisateur'.'membre_utilisateur' = 'Debutant'
AND 'utilisateur'.'pupitre_utilisateur' = 'Tromptte' ";
    $result = $bdd->query($sql);
$columns = $result->fetch();
    
    $nb = $columns['nb'];

    if($nb>0){
	echo'<tr>';
		echo'<th width="25%" class="table-sous-entete">Tambour</th>'; 
	echo'</tr>';
}
while ($donnees = $resultats->fetch()){	
	echo'<tr>';
		echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>';
	echo'</tr>';
}
?>
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
22 févr. 2011 à 21:43
essais de modifier la requête
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant'
AND utilisateur.pupitre_utilisateur = 'Tromptte' ";
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
22 févr. 2011 à 23:00
Ca commence à prendre forme il n'y a déjà plus de message d'erreur et le titre "trompette" ne s'affiche pas lorsqu'il n'y a pas d'utilisateur associé à cet instrument.

Mais par contre les noms et prénom des utilisateurs ne s'affiche pas ça proviens surement de la boucle while?

Merci encore de votre bonté et de votre temps passé à mon problème.
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
23 févr. 2011 à 15:57
pour les noms je sais pas trop mais pour les prénoms
Il faut modifier
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->nom_utilisateur.'</td>';
par
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>';

0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
23 févr. 2011 à 18:21
Bonjour revoilà le script complet pour vvoir si tu peux me trouver la solution pour afficher les données il n'y a plus que ça.
Sinon le reste c'est nickel.
Très sincérement merci


<?php
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant'
AND utilisateur.pupitre_utilisateur = 'Tambour' ";

$result = $bdd->query($sql);
$columns = $result->fetch();

$nb = $columns['nb'];

if($nb>0){
echo'<tr>';
echo'<th width="25%" class="table-sous-entete">Tambour</th>';
echo'</tr>';
}
while ($donnees = $resultats->fetch()){
echo'<tr>';
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>';
echo'</tr>';
}
?>
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
23 févr. 2011 à 18:49
<?php 
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant' 
AND utilisateur.pupitre_utilisateur = 'Tambour' "; 

$result = $bdd->query($sql); 
$columns = $result->fetch(); 

$nb = $columns['nb']; 
echo'<table><tbody>';
if($nb>0){ 
echo'<tr>'; 
echo'<th width="25%" class="table-sous-entete">Tambour</th>'; 
echo'</tr>'; 
} 
while ($donnees = $resultats->fetch()){	
echo'<tr>'; 
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>'; 
echo'</tr>'; 
} 
echo'</tbody></table>';
?>

Sinon t'es sur que la table utilisateur n'est pas vide?
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
23 févr. 2011 à 19:56
En fait dans ma BDD table utilisateur il y a bien 2 membres qui correspond à l'instrument "tambour"

Et dans mon tableau il ne sont pas affiché.
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
Modifié par tito23 le 23/02/2011 à 21:11
Voici le nouveau code
 $sql= "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant'   
AND utilisateur.pupitre_utilisateur = 'Tambour' ";   

$result = $bdd->query($sql);   
$columns = $result->fetch();   

$nb = $columns['nb'];   
  
if($nb>0){   
echo'<tr>';   
echo'<th width="25%" class="table-sous-entete">Tambour</th>';   
echo'</tr>';   
}   
while ($donnees = $resultats->fetch()){   
echo'<tr>';   
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>';   
echo'</tr>';   
}   
echo'</table></td></tr></table>';  
?> 

Sinon tu veux pas essayer avec un code non orienté objet?
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
23 févr. 2011 à 21:07
J suis désolé toujours pareil rien ne s'affiche j'ai bien défini $bdd dans mon fichier de connexion.

//On cré l'objet $bdd à l'aide de la commande new suivi du nom de la classe
$bdd = new PDO('mysql:host=' . $PARAM_hote . ';dbname=' . $PARAM_nom_bdd, $PARAM_utilisateur, $PARAM_mot_passe);
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
23 févr. 2011 à 21:29
Voici le nouveau code
$sql= "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant'
AND utilisateur.pupitre_utilisateur = 'Tambour' ";

$result = $bdd->query($sql);
$columns = $result->fetch();

$nb = $columns['nb'];

if($nb>0){
echo'<tr>';
echo'<th width="25%" class="table-sous-entete">Tambour</th>';
echo'</tr>';
}
while ($donnees = $resultats->fetch()){
echo'<tr>';
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>';
echo'</tr>';
}
echo'</table></td></tr></table>';
?>

Sinon tu veux pas essayer avec un code non orienté objet?
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
23 févr. 2011 à 21:49
Hélas ça ne fonctionne toujours pas

Mais j'ai tout mon site en POO.
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
Modifié par tito23 le 23/02/2011 à 21:58
tu as dit dans un post précédent "mais par contre ça affiche bien les utilisateurs. "
Vraiment c'est bizarre sinon essaie de copier coller le code tout complet.
0
troubadour2 Messages postés 277 Date d'inscription vendredi 11 juin 2010 Statut Membre Dernière intervention 19 juin 2016 1
23 févr. 2011 à 22:26
Voilà en fait avec se script ça affiche bien les utilisateurs mais ça affiche aussi le titre dans ce cas "tambour" même si il n'y a pas d'utilisateur qui correspond à "Tambour".

Contrairement à votre script c'est le contraire.
C'est très complexe mais j'aimerai tant pouvoir y arriver.

<table style="width:25%; float:left"> 
	<tr>
		<td class="table-separateur">
<table width="100%" border="2" cellspacing="1" cellpadding="5">
	<tr>
		<td class="table-entete">DEBUTANT</td>
	</tr>
	
	<tr>
		<th width="25%" class="table-sous-entete">Tambour</th> 
	</tr>
<?php
$resultats = $bdd->query("SELECT * FROM utilisateur WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant' AND 'utilisateur'.'pupitre_utilisateur' = 'Tambour' ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);

while ($donnees = $resultats->fetch())
{
?>	
<td width="25%" class="table-ligne1"><?php echo $donnees->nom_utilisateur . ' ' . $donnees->prenom_utilisateur; ?></td>	
	</tr>
<?php
}
?>
</table>
		</td>
	</tr>
</table>
0
tito23 Messages postés 305 Date d'inscription mardi 10 août 2010 Statut Membre Dernière intervention 16 janvier 2013 4
23 févr. 2011 à 22:41
<?php 
$sql = "SELECT COUNT(*) AS nb FROM utilisateur where utilisateur.membre_utilisateur = 'Debutant' 
AND utilisateur.pupitre_utilisateur = 'Tambour' "; 

$result = $bdd->query($sql); 
$columns = $result->fetch(); 

$nb = $columns['nb']; 
$resultats = $bdd->query("SELECT * FROM utilisateur WHERE 'utilisateur'.'membre_utilisateur' = 'Debutant' AND 'utilisateur'.'pupitre_utilisateur' = 'Tambour' ORDER BY nom_utilisateur ASC");
$donnees = $resultats->setFetchMode(PDO::FETCH_OBJ);
if($nb>0){ 
echo'<tr>'; 
echo'<th width="25%" class="table-sous-entete">Tambour</th>'; 
echo'</tr>'; 
} 
while ($donnees = $resultats->fetch()){	
echo'<tr>'; 
echo'<td width="25%" class="table-ligne1">'.$donnees->nom_utilisateur.' '.$donnees->prenom_utilisateur.'</td>'; 
echo'</tr>'; 
} 
echo'</table></td></tr></table>'; 
?>

ça doit marcher mnt.
Merci de changer le problème en résolu quand vous trouvez une solution
0