|
|
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
Здравствуйте. Не получается решить такой вопрос: Без процедурных расширений, можно ли сделать подобный запрос? case when select not exists (%query%) then select true else %query% --этот запрос возвращает 2 столбца со значениями end; Как бы сделать выбор, если запрос null, то вывести true, если там что-то есть, то вывести их ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.03.2016, 14:03 |
|
||
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
timik0992, Если у вас встречаются null-значения, то так: Код: sql 1. 2. Если надо гарантированно вернуть записи, даже если нет попадающих в условия, то либо через внешние связки, либо через UNION + ORDER BY + LIMIT что-то мутить. Вроде ещё был какой-то красивый выверт для подобного, но я не помню :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.03.2016, 14:58 |
|
||
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
timik0992Здравствуйте. Не получается решить такой вопрос: Без процедурных расширений, можно ли сделать подобный запрос? case when select not exists (%query%) then select true else %query% --этот запрос возвращает 2 столбца со значениями end; Как бы сделать выбор, если запрос null, то вывести true, если там что-то есть, то вывести их Т.е. в зависимости от запроса количество колонок в ответе будет разное - если да то это невозможно (даже с pl/pgsql). -- Maxim Boguk www.postgresql-consulting.ru ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.03.2016, 02:26 |
|
||
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
Maxim Boguk, Мой query возвращает bool, integer. Ну можно в условии then сделать: select true, 1. Тогда так возможно будет? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.03.2016, 13:53 |
|
||
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
timik0992, Криво это конечно, и простительно может быть в том случае, когда приложение поменять нельзя, но есть возможность(хуки) подсунуть свой запрос. Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.03.2016, 14:44 |
|
||
|
Выбор другого запроса, если он null
|
|||
|---|---|---|---|
|
#18+
Павел Лузановtimik0992, Криво это конечно, и простительно может быть в том случае, когда приложение поменять нельзя, но есть возможность(хуки) подсунуть свой запрос. Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. Я бы еще на самом деле WITH бы для запроса сделал вида: Код: plsql 1. 2. 3. 4. Тогда и запрос не будет 2 раза выполнятся и вписывать его 2 раза не придется. -- Maxim Boguk www.postgresql-consulting.ru ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.03.2016, 03:35 |
|
||
|
|

start [/forum/topic.php?fid=53&msg=39200512&tid=1997329]: |
0ms |
get settings: |
5ms |
get forum list: |
9ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
171ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
30ms |
get tp. blocked users: |
1ms |
| others: | 213ms |
| total: | 442ms |

| 0 / 0 |
