Обикновено функциите mysql_* се използват, както следва:
$id = 1234;
$query = 'SELECT name, genre FROM sometable WHERE id=' . $id;
// $query is a string with the MySQL query
$resource = mysql_query($query);
// $resource is a *MySQL result resource* - a mere link to the result set
while ($row = mysql_fetch_assoc($resource)) {
// $row is an associative array from the result set
print_r($row);
// do something with $row
}
Ако предадете нещо на mysql_fetch_assoc, което не е ресурс за резултат на MySQL (независимо дали е низ, обект или булев), функцията ще се оплаче, че не знае какво да прави с параметъра; което е точно това, което виждате.
Обикновен проблем :получавате това предупреждение, ако подадете нещо (различно от валиден низ за заявка) на mysql_query
:
$id = null;
$query = 'SELECT name, genre FROM sometable WHERE id=' . $id;
$res = mysql_query($query);
// $res === FALSE because the query was invalid
// ( "SELECT name, genre FROM sometable WHERE id=" is not a valid query )
mysql_fetch_assoc($res);
// Warning: don't know what to do with FALSE, as it's not a MySQL result resource