Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Не работает метод $result->free()
Форумы портала PHP.SU » » Вопросы новичков » Не работает метод $result->free()

Страниц (1): [1]
 

1. Kave - 24 Июля, 2011 - 13:54:45 - перейти к сообщению
Получаю ошибку
CODE (htmlphp):
скопировать код в буфер обмена
  1. Fatal error: Call to a member function free() on a non-object in Z:\home\vovan.ru\www\results.php on line 43


Строка 43 у меня - это $result->free();

У меня установлен Denwer.
Скажите, от чего такая ошибка? Я подозреваю, что прога не получает доступа к объектам библиотеки mysqli. Может, из-за Денвера.

В любом случае был бы признателен за совет.
Мой код (из книжки):

CODE (htmlphp):
скопировать код в буфер обмена
  1. <html>
  2. <head>
  3. <title>Магазин "Буквофил" - результаты поиска</title>
  4. </head>
  5. <body>
  6. <h1>Магазин "Буквофил" - результаты поиска</h1>
  7. <?php
  8. //Создание коротких имен переменных
  9. $searchtype=$_POST['searchtype'];
  10. $searchterm = trim($_POST['searchterm']);
  11. if (!$searchtype||!$searchterm) {
  12.    echo "Вы не ввели параметры поиска. Вернитесь
  13.    на предыдущую страницу и повторите ввод.";
  14.    exit;
  15. }
  16.  
  17. $serachtype=addslashes($searchtype);
  18. $serachterm=addslashes($searchterm);
  19. }
  20. @ $db = new mysqli('localhost','bookorama','bookorama123','books');
  21. echo "Ошибка: Не удалось установить соединение с базой данных.
  22. Повторите попытку позже.";
  23. }
  24. $query = "select * from books where " . $searchtype . "like '%" . $searchterm."%'";
  25. $result =$db->query($query);
  26. $num_results = $result -> num_rows;
  27. echo "<p>Найдено книг: ". $num_results."</p>";
  28. for ($i=0;$i<$num_results; $i++){
  29.    $row = $result->fetch_assoc();
  30.    echo "<p><strong>".($i+1).". Название: ";
  31.    echo htmlspecialchars (stripslashes($row['title']));
  32.    echo "</strong><br/> Автор: ";
  33.    echo stripslashes ($row['author']);
  34.    echo "<br/>ISBN: ";
  35.    echo stripslashes ($row['isbn']);
  36.    echo "<br/>Цена: ";
  37.    echo stripslashes($row['price']);
  38.    echo "</p>";
  39. }
  40. $result->free();
  41. $db->close();
  42. ?>
  43. </body>
  44. </html>
2. Kave - 24 Июля, 2011 - 14:21:01 - перейти к сообщению
Все-таки на всякий случай мой php.ini.
Допмодуль для Denwer'а поставил (см. скриншот).
3. Kave - 24 Июля, 2011 - 14:41:59 - перейти к сообщению
Скриншот.

 

Powered by ExBB FM 1.0 RC1