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 :: Версия для печати :: Объеденить несколько UPDATE
Форумы портала PHP.SU » » Работа с СУБД » Объеденить несколько UPDATE

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

1. zzzzzz - 04 Ноября, 2013 - 16:40:44 - перейти к сообщению
Здравствуйте. Имеются 3 запроса у которых WHERE один и тот же.

$psql4 = "UPDATE node SET `title`='%s', `show`='%s' WHERE nid='%s'";
$psql5 = "UPDATE field_data_body SET `body_value`='%s' WHERE nid='%s'";
$psql7 = "UPDATE field_data_category SET `category_id`='%s' WHERE nid='%s'";

Могу объединить с помощью UNION но думаю есть более грациозная реализация

Спасибо
2. teddy - 04 Ноября, 2013 - 17:20:33 - перейти к сообщению
Если нужно обновить одним запросом три таблицы, тогда можно использовать multi_query, который нам предлагает MySQLi

Только буква p в начале каждой переменной насторожила.. если вы используете PostgreSQL
тогда вот пример из мануала, в принципе одно и то же
http://us2.php.net/manual/ru/fun...ion.pg-query.php
(Добавление)
Если нужно использовать один раз ключевое слово WHERE, то можно ещё так:
CODE (SQL):
скопировать код в буфер обмена
  1. UPDATE `node`, `field_data_body`, `field_data_category` SET `node`.`title`='%s',
  2. `field_data_body`.`body_value`='%s', `field_data_category`.`category_id`='%s' WHERE `node`.`nid`='%s' AND `field_data_body`.`nid`='%s' AND `field_data_category`.`nid`='%s'
3. zzzzzz - 04 Ноября, 2013 - 17:44:16 - перейти к сообщению
После WHERE используются три поля nid с одинаковыми значениями, соответственно передать в sprintf() нужно три одинаковых переменных.



Правильно ли это?
(Добавление)
нужно что-то типа WHERE *.nid = '%s'
(Добавление)
и psql это у меня pattern sql )))
4. teddy - 04 Ноября, 2013 - 17:48:31 - перейти к сообщению
zzzzzz пишет:
Правильно ли это?

Не думаю. Если у вас одинаковые значения, зачем трижды вызывать эту функцию и создавать разные переменные? Достаточно создать 1 переменную и положить в нее то значение, которое везде одинаковое и в запрос уже в 3 местах подставлять эту переменную.
5. zzzzzz - 04 Ноября, 2013 - 18:03:03 - перейти к сообщению
функцию вызываю один раз, но как вы видите после WHERE в запросе стоят три маркера у которых одинаковое значение, соответственно эти маркеры я должен заполнить и получается так

sprintf(..., $nid, $nid, $nid)
6. teddy - 04 Ноября, 2013 - 18:18:22 - перейти к сообщению
Если полученная строка устраивает вас как результат, то можно и даже нужно для корректного апдейта данных.
7. zzzzzz - 04 Ноября, 2013 - 18:29:16 - перейти к сообщению
Устраивает полностью, спасибо
8. deblogger - 05 Ноября, 2013 - 04:34:09 - перейти к сообщению
zzzzzz пишет:
есть более грациозная реализация


Есть. Переделать бд так, чтобы не пришлось писать 3 одинаковых значения в три разные таблицы.

 

Powered by ExBB FM 1.0 RC1