web-dev-qa-db-fra.com

Erreur fatale: appel à la fonction non définie mysqli_result ()

Quelqu'un peut-il me dire pourquoi cela ne fonctionne pas, lorsque j'ai essayé de passer mon ancien sql en sqli:

$query = "SELECT * FROM `product_category`";
$result = mysql_query($query, $connect) or die("could not perform query: " . mysql_error());
$num_rows = mysql_num_rows($result);

for ($i=0; $i < $num_rows; $i++)
{
    $ID = mysql_result($result,$i,"ID");
    $name = mysql_result($result,$i,"name");
    $description = mysql_result($result,$i,"description");

à:

$query = ("SELECT * FROM `product_category`");
$result = mysqli_query($connect, $query) or die("could not perform query");
$num_rows = mysqli_num_rows($result);

for ($i=0; $i < $num_rows; $i++)
{
    $ID = mysqli_result($result, "ID");
    $name = mysqli_result($result,$i,"name");
    $description = mysqli_result($result,$i,"description");`

il me donne toujours une erreur de: "Erreur fatale: Appel à la fonction non définie mysqli_result ()"

14
Cesarg219

N'utilisez pas ce type de code. C'est très inefficace. Utilisez à la place mysqli_fetch_assoc():

while($row = mysqli_fetch_assoc($result)) {
   $id = $row['ID'];
   $name = $row['name']; 
   etc..
}

Une seule opération de base de données, plutôt que les 3+ que vous essayez de faire.

18
Marc B
function mysqli_result($res, $row, $field=0) { 
    $res->data_seek($row);
    $datarow = $res->fetch_array();
    return $datarow[$field];
} 

Vous pouvez créer cette fonction

0
Roman Panevnyk