powered by simpleCommunicator - 2.0.41     © 2025 Programmizd 02
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / как пройтись по набору записей?
8 сообщений из 8, страница 1 из 1
как пройтись по набору записей?
    #32238887
Пупкин
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ищу в букваре намек на условный переход в диалекте PostgreSQL - для прохода по курсору (по аналогии с MSSQL), - не нахожу. Как пройтись по набору записей?


__
Буквально задача: есть выборка; в зависимости от значений вставляем данные из нее в пару таблиц, и обновляем несколько полей в таблице выборки. Реализовал пока как транзакцию из запросов на обновление. Но неудобство в том, что ключи (в одной из таблиц) вставки "наборные" - из 3-х (4-х) полей, версия PostgreSQL 7.0.2 на попытки LEFT/RIGHT JOIN-ов отругивается в том смысле, что OUTER JOIN "пока не реализован", т.ч. для вставки пользую вложенный запрос с NOT EXIST(Select ...), который, как я понимаю, исполняется для каждой записи, т.е. время исполнения растет квадратично от числа записей... К тому же даже в случае если я исхитрюсь заменить (именно этот) запрос на что нибудь с EXCEPT (NOT IN не прокатывает -ключ многоколончатый, а сшивать поля в одно функцией - терять преимущество индексов), время исполнения которого должно, на вскидку, "расти линейно" с числом записей, все равно логика простой прогонки по набору вместо многочисленных запросов к разным таблицам "прямее".

Может быть я решаю задачу не с того конца, и нужно поюзать другие, употребительные именно в PostgreSQL методы? Кто как думает?/делает? Подскажите чайнику.
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32238920
Пупкин
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сорри, ... WHERE (a,b,c) IN (SELECT t.a, t.b, t.c FROM atable as t ...) прокатывает (и похоже "девствительно" быстро), но вопрос по условным переходам остается.
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32239203
Vel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Используй финкции. Ну типа вот этого:

...
declare
rec record;
....
for rec in select * from bla-bla-bla (query) loop
if rec.id=1 then
...
end if;
if rec.id=2 then
...
end if;
....
end loop;
...
end;
...

Примерно так, если я тебя правильно понял. Т.е. выполняется запрос и лупом прогоняем строки от 1 до сколько их есть
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32239586
Пупкин
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
1. Спасибо, я и искал конструкцию типа loop и/или if но это в каком языке? (в букваре не нашел). Попробую на досуге, поймет ли PostgreSQL эту конструкцию?

!!!
2. Я рано радовался (см 1-й пост):
Конструкции

SELECT A,B,C FROM t1 EXCEPT (SELECT A,B,C FROM t2);
и
SELECT A,B,C FROM t1 INTERSECT (SELECT A,B,C FROM t2);

не взаимополные?!!! (есть данные, не попадающие ни в один набор)
по крайней мере в PostgreSQL 7.0.2

то же самое c

SELECT * FROM t1 WHERE (A,B,C) IN(SELECT A,B,C FROM t2);
и
SELECT * FROM t1 WHERE (A,B,C) NOT IN(SELECT A,B,C FROM t2);
не взаимополные?!!!

!ЛЮДИ, я туплю, и так и должно быть??? (уже себе не верю)
или это действительно баг версии? Есть ли это и в
PostgreSQL 7.3.х ???
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32239606
Пупкин
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Вопрос о 7.3.3. снят:

Действительно моя тупость: в подзапросе (с EXCEPT() или NOT IN() не должно быть полей с NULL, в противном случае возращается пустое множество записей. И наборы действительно не дополнительны. Простейший пример:

SELECT lt.a
FROM lt
except (select null);

или:

SELECT lt.a
FROM lt
WHERE a NOT IN(select null);
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32239895
Vel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Отходи от 7,2,*. Там нет даже create or REPLACE function - нет replace.
И не забудь в конце писать language 'plpgsql'. Скорее всего это именно его структуры
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32240133
Пупкин
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
to Vel:
1. спасибо. Действительно это не SQL, а
PL/pgSQL . Вычитал с утра. Но его еще подключить надо. А я не суперюзер :о(

2. если бы 7.2.х! - 7.0.2. Пишу ему вложенный запрос - ругается. Долго бьюсь, потом проверяю: пишу простейшее:

SELECT q.id
FROM (SELECT * FROM company) AS q;

ругается! Вспоминаю, что не первый раз (с множественным join-ом было то же). Через вью не напишешься. Да во вью и юнионы не впихиваются. И прочая какая-то тягомотина.

7.3 обещают в перспективе. (7.0.2 задействован в текущих задачах, пока не трогаем).
...
Рейтинг: 0 / 0
как пройтись по набору записей?
    #32240375
Vel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добавить язык - createlang plpgsql template1 - чтобы на все новосозданные таблицы передавалось.
createlang plpgsql mydb - на твою базу.
Админу, я думаю не тяжело будет две строки напедалить :).
А то, что 7.0.2 - мои искренние соболезнования. Пациент скорее мертв, чем жив.
Я после апгрейда на 7.3.3 почувствовал прелесть жизни.
...
Рейтинг: 0 / 0
8 сообщений из 8, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / как пройтись по набору записей?
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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