С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805

Остановка скрипта при update

16.10.2010, 14:12. Показов 1515. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет. Возникла проблема остановки скрипта при большом количестве запросов в базу. Вот пример

Есть массив $array в нем куча всякой информации. Дальше делаю форич

PHP
1
2
3
4
5
6
echo "Начали";
foreach ( $array AS $key=>$value){
........ обработка; 
mysql_query("UPDATE table SET name='".$value['name']."' WHERE id=".$value['id']." ");
}
echo "Закончили";
когда это запускаю, у меня не выводится слово "Закончили"!
Немного замарочившись, переделал так


PHP
1
2
3
4
5
6
7
8
9
10
11
echo "Начали";
$i=0;
foreach ( $array AS $key=>$value){
........ обработка; 
mysql_query("UPDATE table SET name='".$value['name']."'  WHERE id=".$value['id']."  ");
$i++;
if ($i==300){
breake;
}
}
echo "Закончили";
Вот теперь слово " ЗАКОНЧИЛИ" появилось.
В какую сторону копать? почему скрипт стопорится?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.10.2010, 14:12
Ответы с готовыми решениями:

Остановка php скрипта
Возникла следующая проблема: имеется некий пхп скрипт, который отрабатывает примерно 3000 секунд. Переехали на новый сервер, и...

Принудительная остановка выполнения скрипта
Не знаю в какую тему писать так что пишу тут(не серчайте пожалуйста) В общем ситуация такая, имеется скрипт, в который не аккуратно...

Остановка выполнения скрипта при нажатии на кнопку Cancel
Товарищи, доброго времени суток, есть скрипт, данные в него заносятся с помощью форм. Конструктор формы взят в Microsoft. Add-Type...

8
 Аватар для Nazz
898 / 729 / 80
Регистрация: 12.03.2009
Сообщений: 2,804
Записей в блоге: 2
16.10.2010, 15:46
а может так:
PHP
1
2
3
4
5
6
7
8
9
10
11
echo "Начали";
$i=0;
foreach ( $array AS $key=>$value){
........ обработка; 
mysql_query("UPDATE table SET name='".$value['name']."'  WHERE id=".$value['id']."  ");
$i++;
if ($i==300){
exit();
}
}
echo "Закончили";
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
16.10.2010, 21:11  [ТС]
Вы меня наверное не поняли. Мне не нужно весь скрипт останавливать! Мне надо чтобы он продолжил совю работу без остановки цикла на 300-ой итерации. поидее он 300 раз обращается к базе (Делает апдейт) а потом почему-то останавливается. Если я в условии поставлю 301 то скрипт не выводит слово "Закончилось". Либо это гдето в найстройках бд делается, либо в настройках пхп. вот только где? и правильно ли я думаю?
0
 Аватар для Nazz
898 / 729 / 80
Регистрация: 12.03.2009
Сообщений: 2,804
Записей в блоге: 2
16.10.2010, 21:52
значит так:
PHP
1
2
3
4
5
6
7
8
9
10
11
echo "Начали";
$i=0;
foreach ( $array AS $key=>$value){
........ обработка; 
if ($i<=300)
{
mysql_query("UPDATE table SET name='".$value['name']."'  WHERE id=".$value['id']."  ");
$i++;
}
}
echo "Закончили";
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
16.10.2010, 22:31
Попробуй так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
error_reporting(E_ALL); // показывать все ошибки
echo "Начали";
foreach ( $array AS $key=>$value){
........ обработка; 
$r = @mysql_query("UPDATE table SET name='".$value['name']."' WHERE id=".$value['id']." "); // @ означает, что даже в случае ошибки продолжать работу
if (!$r) // если запрос закончился неудачей
{
  echo 'Ошибка в запросе: ';
  echo mysql_errno().' ';
  echo mysql_error();
  echo 'Содержимое value:';
  print_r($value);
  break;
}
}
echo "Закончили";
Может, забываешь сделать addslashes() для передаваемых данных? И на 300-й строке просто попадаются данные с кавычкой или каким-нибудь другим спецсимволом.
0
 Аватар для suharik
261 / 247 / 57
Регистрация: 03.09.2010
Сообщений: 805
18.10.2010, 11:52  [ТС]
Humanoid,
спасибо за код. Но при нем,
PHP
1
2
3
 echo 'Ошибка в запросе: ';
  echo mysql_errno().' ';
  echo mysql_error();
Скрипт останавливается, а это не выводится)
0
 Аватар для Nazz
898 / 729 / 80
Регистрация: 12.03.2009
Сообщений: 2,804
Записей в блоге: 2
18.10.2010, 12:01
а так:
PHP
1
echo "Ошибка в запросе: ".mysql_errno()." ".mysql_error();
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
18.10.2010, 12:04
Сейчас на всякий случай попробовал у себя так сделать... 900 UPDATE'в проходят без проблем. Может, у тебя в обработке где-нибудь скрипт спотыкается? И какая версия PHP ?

Добавлено через 1 минуту

Не по теме:

Nazz, это тоже самое... я стараюсь, mysql_error выводить отдельно и в конце, т.к. когда-то был случай, что PHP спотыкался на этой функции... поэтому я теперь перестраховываюсь :)

0
 Аватар для Sonax
350 / 76 / 10
Регистрация: 13.10.2010
Сообщений: 830
19.10.2010, 03:18
в php.ini глянь, максимальное время работы скрипта увелич
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.10.2010, 03:18
Помогаю со студенческими работами здесь

Остановка скрипта
Есть скрипт, который строит карту и выделяет области, в зависимости от курсора мыши... $(function(){ var param; var r =...

[Pawn] Остановка на конечной точке, или остановка поворота при достижении заданного угла
Всем здравствуйте. У меня такой вопрос, реализация, по возможности более просто, остановка на конечной точке, или остановка поворота, при...

Принудительная остановка скрипта
Крон запускает скрипт допустим каждую минуту но иногда изза циклов и курлов он зацикливается, и может так несколько раз запускаться и еще...

Остановка скрипта в PHP
Здравствуйте. Как в этой случае - остановить скрипт. А то когда не вводишь ничего, то выдается как положено и не правильно, т.е все...

Запуск и остановка bash - скрипта
есть bash - скрипт #!/bin/bash while true do php test.php sleep 3s done как сделать комманды start stop и restart ?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru