Dans ce code d'un petit moteur de recherche, j'obtiens l'erreur Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in /.../ on line 85
while($req = mysql_fetch_array($requete))
Une idée ?
Merci de votre aide
Modifié par whynote (02 Nov 2010 - 23:39)
while($req = mysql_fetch_array($requete))
Une idée ?
Merci de votre aide
<?php require_once('../cours.php'); ?>
<?php
//On determine l'expression a rechercher
if(isset($_GET['recherche']))
{
$rec = htmlentities($_GET['recherche']);
}
else
{
$rec = 'chopin';
}
//On determine le type de recherche
if(isset($_GET['type']))
{
if($_GET['type']=='un')//Un des mots
{
$type = 1;
}
elseif($_GET['type']=='tout')//Tout les mots
{
$type = 2;
}
else//L'expression exacte
{
$type = 3;
}
}
else
{
$type = 1;//type par defaut: L'expression exacte
}
//On determine si on doit surligner les mots dans les resultats
if(!isset($_GET['surligner']) or $_GET['surligner']!='true')
{
$surligner = false;
}
else
{
$surligner = true;
}
$req = 'SELECT nomcompo, professeurID, oeuvre FROM cours WHERE ';
if($type==1)
{//ayant un des mots dans leurs informations
$mots = explode(' ',$rec);//En separre lexpression en mots cles
foreach($mots as $mot)
{
$req .= ' oeuvre LIKE "%'.$mot.'%" OR';
}
$req .= ' 1=0';
}
elseif($type==2)
{//ayant tout des mots dans leurs informations
$mots = explode(' ',$rec);//En separre lexpression en mots cles
foreach($mots as $mot)
{
$req .= ' oeuvre LIKE "%'.$mot.'%" AND';
}
$req .= ' 1=1';
}
else
{//ayant l'expression exacte dans leurs informations
$req .= 'oeuvre LIKE "%'.$rec.'%"';
}
//Les utilisateur seront ranges par nomcompoentifiant en ordre croissant
$req .= ' order by nomcompo asc';
$requete = mysql_query($req);
//Le formulaire de recherche
?>
<form action="" method="get">
Expression à rechercher: <input type="text" name="recherche" value="<?php echo $rec; ?>" /><br />
Type de recherche: <input type="radio" name="type" value="un"<?php if($type==1){echo 'checked="checked"';} ?> /> Un des mots <input type="radio" name="type" value="tout"<?php if($type==2){echo 'checked="checked"';} ?> /> Tout les mots <input type="radio" name="type" value="exacte"<?php if($type==3){echo 'checked="checked"';} ?> /> Expression exacte<br />
Mettre en gras les mots recherchés: <input type="checkbox" name="surligner" value="true" <?php if($surligner){echo 'checked="checked"';} ?> /><br />
<input type="submit" value="Rechercher" />
</form>
<h2>Résultats</h2>
<table>
<tr>
<th>Identifiant</th>
<th>Nom</th>
<th>Informations</th>
</tr>
<?php
//On affiche les resultats
while($req = mysql_fetch_array($requete))
{
?>
<tr>
<td><?php echo $req['nomcompo']; ?></td>
<td><?php echo $req['professeurID']; ?></td>
<td><?php
if($surligner)//Si il faut surligner les mots, on les surligne
{
if($type==3)
{
echo preg_replace('#('.preg_quote($rec).')#i', '<strong>$1</strong>', $dnn['oeuvre']);//On surligne l'expression exacte
}
else
{
echo preg_replace('#('.str_replace(' ','|',preg_quote($rec)).')#i', '<strong>$1</strong>', $dnn['oeuvre']);//On surligne les mots cles de la recherche
}
}
else
{
echo $dnn['oeuvre'];//On ne surligne pas
}
?></td>
</tr>
<?php
}
?>
</table>
Modifié par whynote (02 Nov 2010 - 23:39)