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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Множественный update

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Опрос
Множественный update
Для голосования и просмотра результатов опроса войдите или зарегистрируйтесь

> Без описания
romanov
Отправлено: 24 Августа, 2014 - 15:09:52
Post Id


Гость


Покинул форум
Сообщений всего: 112
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




Здравствуйте, как лучше сделать update 600 записей, использовать Update в цикле

CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. UPDATE `sites_pages` SET LINK_NAME = 'Правила использования'
  3. WHERE `LINK` = '/rules/'
  4.  

или такую конструкцию


CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. UPDATE TABLE SET Col1 = CASE id
  3.                           WHEN 1 THEN 1
  4.                           WHEN 2 THEN 2
  5.                           WHEN 4 THEN 10
  6.                           ELSE Col1
  7.                         END,
  8.                  Col2 = CASE id
  9.                           WHEN 3 THEN 3
  10.                           WHEN 4 THEN 12
  11.                           ELSE Col2
  12.                         END
  13.              WHERE id IN (1, 2, 3, 4);
  14.  
  15.  


Зачем вообще id IN () нужен ?
 
 Top
OrmaJever Модератор
Отправлено: 24 Августа, 2014 - 17:50:33
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




если "Правила использования" для каждой записи свои то по-моему одним запросом не вариант, городить кучу WHEN - THEN - бред.
Я бы использовал prepare в цикле

PHP:
скопировать код в буфер обмена
  1. $pre = $PDO->prepare('UPDATE `sites_pages` SET LINK_NAME = ? WHERE `LINK` = ?');
  2.  
  3. while( ... ) { // foreach, for
  4.   $pre->execute( array( $link_name, $link ) );
  5. }


Но учтите что на страницах куда имеет доступ обычный пользователь таких множественных апдейтов быть не должно потому что плохие пользователи могут так и базу положить, а для админки или крона в цикле вполне нормально.


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
romanov
Отправлено: 24 Августа, 2014 - 20:02:57
Post Id


Гость


Покинул форум
Сообщений всего: 112
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




Хороший совет, у меня как раз в админке и пользователи апдейты не делают, вот только у меня битрикс и так классов как в PDO, так вот такое есть:

PHP:
скопировать код в буфер обмена
  1.  
  2. $strUpdate = $DB->PrepareUpdate("b_form_result_answer", $arFields, "form");
  3.     $strSql = "UPDATE b_form_result_answer SET ".$strUpdate." WHERE RESULT_ID=".$RESULT_ID." and FIELD_ID=".$FIELD_ID;
  4.     $DB->Query($strSql, false, $err_mess.__LINE__);
  5.  


То есть получается что в условии нельзя подготавливать данные. Может покажете как это будет на чистом mysql без pdo
 
 Top
OrmaJever Модератор
Отправлено: 24 Августа, 2014 - 20:05:48
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




romanov пишет:
Может покажете как это будет на чистом mysql без pdo

на чистом mysql нету prepare statement, они есть в PDO либо в mysqli. Я уверен что какой-то из них у вас установлен, гляньте в phpinfo()


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
romanov
Отправлено: 24 Августа, 2014 - 20:15:39
Post Id


Гость


Покинул форум
Сообщений всего: 112
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




mysqli и pdo не смогу использовать в данном случае , потому что соединение установлено битриксом и т.д.

Что вы имели виду когда писали
OrmaJever пишет:
если "Правила использования" для каждой
?
 
 Top
OrmaJever Модератор
Отправлено: 24 Августа, 2014 - 20:42:50
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




romanov пишет:
Что вы имели виду когда писали

romanov пишет:
SET LINK_NAME = 'Правила использования'

новое значение LINK_NAME разное для всех обновляемых полей?


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
romanov
Отправлено: 24 Августа, 2014 - 22:39:05
Post Id


Гость


Покинул форум
Сообщений всего: 112
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




OrmaJever пишет:
новое значение LINK_NAME разное для всех обновляемых полей?


Да разное
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB