Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > MySQL > Обновить одно поле в 10 таблицах махом


Автор: Golovastik 16.3.2011, 16:43
Нужно обновить поле обновление в 10 таблицах махом, процедуркой или функцией МАЙСКЛ как это сделать?
update lessons1 set obnovlenie= 0 where id>0;
Мне нужно за 1 раз сделать это с lessons1-lessons10.
Как это сделать?

Автор: Akina 16.3.2011, 16:54
Код

update lessons1 set obnovlenie=0 where id>0;update lessons2 set obnovlenie=0 where id>0;upd...re id>0;update lessons10 set obnovlenie=0 where id>0;

Автор: Golovastik 16.3.2011, 19:23
Да вы не поняли, мне не так нужно, мне нужно как-то циклом в функции или процедурке.
Как там сделать это? 

Автор: Akina 16.3.2011, 19:46
Используйте в процедуре prepared statement. Схематично:

Код

declare @tnum, @sql;
  set @tnum=1;
  repeat
    set @sql=concat('update lessons',@tnum,' set obnovlenie= 0 where id>0;');
    prepare stmt from @sql;
    execute stmt;
    drop prepare stmt;
    set @tnum=@tnum+1;
  until @tnum>10 end repeat;

Автор: Zloxa 17.3.2011, 10:36
Цитата(Golovastik @  16.3.2011,  19:23 Найти цитируемый пост)
мне не так нужно, мне нужно как-то циклом в функции или процедурке.

Судя потому, что вас не устраивает простое и очевидное наколеночное решение, Вы пытаетесь выполнить не разовую операцию, а строите прикладную логику. Если это так, хотелось бы Вас предупредить, вероятность того, что вы делаете что-то не то - весма высока.

Автор: Akina 17.3.2011, 10:50
Zloxa, да аллах с им... ну грохнет базу разок-другой - подумаешь! он что, первый, что ли?

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)