powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Oracle [игнор отключен] [закрыт для гостей] / merge вместо update
1 сообщений из 1, страница 1 из 1
merge вместо update
    #39372924
Maxifly
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
мне нужно сделать update нескольких записей в очень большой таблице (ну как нескольких - тысяч сто)
при этом, новые значения высчитываются на основе данных из этой же таблицы.

На прототипе как-то так:

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
update pmu_KUKU D
  set (t, r) = 
   ( select dtt, rnn from (
    select rwd,dtt , rownum rnn from (
     select max(rowid) rwd, nvl(max(t),sysdate) + 1 dtt from pmu_kuku where pmu_kuku.w in (1,3) group by w
    )
   ) S
   where S.rwd = D.rowid)
where 
  D.rowid in (select rwd from (
    select rwd,dtt , rownum rnn from (
     select max(rowid) rwd, nvl(max(t),sysdate) + 1 dtt from pmu_kuku where pmu_kuku.w in (1,3) group by w
    )
   ) S )  




если я заменю update на merge, есть какие-то подводные камни или нет? (просто ни от кого не слышал, чтоб так делали)

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
merge into pmu_KUKU D
 using ( 
   select rwd,dtt , rownum rnn from (
     select max(rowid) rwd, nvl(max(t),sysdate) + 1 dtt from pmu_kuku where pmu_kuku.w in (1,3) group by w
   )
 ) S
 on (D.rowid = S.rwd)
when matched then update set D.T = S.dtt, D.r = S.rnn 






Люблю галеры - работящий коллектив, романтика мужского труда. Стоишь на мостике в пене брызг и эдак поворотясь:
- Голубчик! Утроить количество ударов - Али-паша уходит...
...
Рейтинг: 0 / 0
1 сообщений из 1, страница 1 из 1
Форумы / Oracle [игнор отключен] [закрыт для гостей] / merge вместо update
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]