Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / подскажите, плз, как эффективно проапдейтить таблицу / 2 сообщений из 2, страница 1 из 1
06.02.2006, 11:31
    #33525293
vladimir1024
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
подскажите, плз, как эффективно проапдейтить таблицу
Добрый день!

Подскажите, плиз в такой ситуации.

Есть таблица такого вида:

ID____ VALUE____
1_____ 10
2_____ NULL
3_____ NULL
4_____ 20
5_____ NULL
6_____ 30

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

Таблица большая (20 000 000), поэтому нужна эффективность.

Пока делаю так:

UPDATE TT SET VALUE=(SELECT VALUE FROM TT t1 WHERE t1.ID<TT.ID AND ID!=NULL ORDER BY ID LIMIT 1);


Но что-то мне подсказывает, что можно эффективнее.

Заранее благодарю
...
Рейтинг: 0 / 0
07.02.2006, 05:16
    #33527341
фффф
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
подскажите, плз, как эффективно проапдейтить таблицу
Оптимально для быстродействия будет скорее всего курсором. Приведенный же запрос не работает. Правильнее будет:

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
UPDATE TT SET VALUE=(
  SELECT VALUE 
  FROM TT t1 
  WHERE t1.ID<TT.ID 
    AND  ID!=NULL  VALUE IS NOT NULL
  ORDER BY ID DESC
  LIMIT 1
)
WHERE VALUE IS NULL;
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / подскажите, плз, как эффективно проапдейтить таблицу / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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