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 :: Версия для печати :: Хранимая процедура закрывает соединение с базой?
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Хранимая процедура закрывает соединение с базой?

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

1. 4elentano - 07 Апреля, 2012 - 05:48:27 - перейти к сообщению
Был поисковый запрос по словарям
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT id,title,LEFT(text,250) AS prev FROM books WHERE shelf = 1 AND title LIKE '%$search%';

Работало это нормально. Теперь пытаюсь прооптимизировать его. Создал хранимую процедуру в базе:
CODE (SQL):
скопировать код в буфер обмена
  1. DELIMITER /
  2. CREATE PROCEDURE sp_search (IN search TEXT)
  3. BEGIN
  4. SELECT id,title,LEFT(text,250) AS prev FROM books WHERE shelf = 1 AND title LIKE search;
  5. END;
  6. /
  7. DELIMITER ;

Процедуру вызываю, работает нормально, данные передаёт, всё ок.
Проблема: все последующие запросы к базе из рНр-скрипта неудачны.
1. При обращении к базе с использованием результатов работы хранимой процедуры mysql_error() выдаёт: Commands out of sync; you can't run this command now.
2. При всех последующих запросах к базе (никак с этой хранимой процедурой не связанных) пишет: Cannot select DB.

Если я перевожу файл в прежний вид, работа напрямую с SQL-запросом (без хранимой процедуры), всё работает хорошо.

Люди добрые, кто-то понимает в чем там дело и как его исправить? Хочется, чертовски хочется разобраться с этими хэ-процедурами.
Заранее спасибо всем, кто откликнется.
2. dadli - 08 Апреля, 2012 - 13:40:17 - перейти к сообщению
4elentano
покожите как ви визиваите процедуру? кожется что всо должно работать хорошо.
3. 4elentano - 09 Апреля, 2012 - 07:43:33 - перейти к сообщению
dadli, вот вызов процедуры:
PHP:
скопировать код в буфер обмена
  1. $sql_search = mysql_query("CALL sp_search ('%$search%')");

полученные данные пересчитываю с помощью mysql_num_rows() и вывожу сперва количество результатов, (если их больше нуля). Далее в цикле вывожу результаты с помощью mysql_fetch_array();
Если результатов ноль, вывожу просто предложение поискать что-ниб. другое.
Вывод всех данных работает нормально.

Сложность возникает с другими, последующими запросами в базу. Не хочет, сволочь, работать ((
Хотя запросы правильно сформулированы.
4. tuareg - 09 Апреля, 2012 - 09:58:23 - перейти к сообщению
Используйте mysqli_* или PDO
4elentano пишет:
Теперь пытаюсь прооптимизировать его.

Тут нет оптимизации, это так ... Улыбка
5. dadli - 09 Апреля, 2012 - 12:44:03 - перейти к сообщению
4elentano

как tuareg сказкал переделаите свои код mysqli_*

и потом после визова процедуру напишите mysqli_next_result();
потом должен работать следуши запрос

 

Powered by ExBB FM 1.0 RC1