Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
09.12.2004, 14:16
|
|||
|---|---|---|---|
|
|||
PgSQL: Как сделать лучше? |
|||
|
#18+
Есть функция в которой порядок сортировки задаётся в качестве аргумента: автор declare orderby alias for $1; t public.service%ROWTYPE; begin if orderby=1 then for t in select * from public.service order by id loop ..... end loop; end if; if orderby=1 then for t in select * from public.service order by date loop ..... end loop; end if; end; Вопрос: как сократить количество почти одинаковых блоков if которых тут больше 20-ти и в каждой 11 строк? Как можно сформировать селект "на лету"? Заранее благодарен ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
09.12.2004, 19:15
|
|||
|---|---|---|---|
|
|||
PgSQL: Как сделать лучше? |
|||
|
#18+
blackrookЕсть функция в которой порядок сортировки задаётся в качестве аргумента: автор declare orderby alias for $1; t public.service%ROWTYPE; begin if orderby=1 then for t in select * from public.service order by id loop ..... end loop; end if; if orderby=1 then for t in select * from public.service order by date loop ..... end loop; end if; end; Вопрос: как сократить количество почти одинаковых блоков if которых тут больше 20-ти и в каждой 11 строк? Как можно сформировать селект "на лету"? Заранее благодарен Записываешь запрос в переменную типа text. Затем выполняешь: for t in execute query loop ... end loop; ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
10.12.2004, 12:50
|
|||
|---|---|---|---|
|
|||
PgSQL: Как сделать лучше? |
|||
|
#18+
Если в запросе известна последовательность полей, то сотировку можно передавать просто цифрой. Т.е.: "select * from mytable order by 2 ". Нумерация полей для сортировки начинается с единицы. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=53&tablet=1&tid=2007551]: |
0ms |
get settings: |
9ms |
get forum list: |
19ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
153ms |
get topic data: |
14ms |
get forum data: |
4ms |
get page messages: |
53ms |
get tp. blocked users: |
3ms |
| others: | 279ms |
| total: | 540ms |

| 0 / 0 |
