Гость
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Как сделать чтобы запрос с CASE не вывел ни одной строки? / 7 сообщений из 7, страница 1 из 1
11.01.2018, 12:19
    #39582413
acidophilus
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
Добрый день, коллеги.

Нужно чтобы CASE при определенном условии не вывел ни одной строки в запросе.

Подскажите, как это можно сделать?

Пробовал так:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
--так работает, выводит одну строку
SELECT CASE WHEN 1=1 THEN
(SELECT '0' LIMIT 1)::text
END;

--так все равно выводит одну строку
SELECT CASE WHEN 1=1 THEN
(SELECT '0' LIMIT 0)::text
END;

--так не работает
SELECT CASE WHEN 1=1 THEN
(SELECT '0' LIMIT 0)
END;

ОШИБКА: failed to find conversion function from unknown to text
SQL-состояние: XX000


--так все равно выводит 1 строку
SELECT CASE WHEN 1=1 THEN
NULL
END;
...
Рейтинг: 0 / 0
11.01.2018, 12:23
    #39582423
vyegorov
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
acidophilus,

Строки формируются во FROM-части запроса, а не в SELECT-листе.
...
Рейтинг: 0 / 0
11.01.2018, 12:26
    #39582427
acidophilus
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
vyegorovacidophilus,

Строки формируются во FROM-части запроса, а не в SELECT-листе.

Дело в том, что там нет FROM.
...
Рейтинг: 0 / 0
11.01.2018, 12:28
    #39582429
acidophilus
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
В условиях CASE формируется строка, которая от различных уловий по-разному выглядит.

А при определенном условии запрос не должен вообще ни одной строки вернуть.
...
Рейтинг: 0 / 0
11.01.2018, 12:44
    #39582442
Щукина Анна
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
acidophilus,

ну так и пишите это "определенное условие" в кляузе WHERE:

Код: sql
1.
2.
3.
select 1 where case when 2 = 1 then 1 else 2 end = 1; --- не выводит строк

select 1 where case when 1 = 1 then 1 else 2 end = 1; --- выводит одну строку
...
Рейтинг: 0 / 0
11.01.2018, 12:55
    #39582449
acidophilus
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
Щукина Аннаacidophilus,

ну так и пишите это "определенное условие" в кляузе WHERE:

Код: sql
1.
2.
3.
select 1 where case when 2 = 1 then 1 else 2 end = 1; --- не выводит строк

select 1 where case when 1 = 1 then 1 else 2 end = 1; --- выводит одну строку




Так работает.

Большое спасибо, Анна.


...
Рейтинг: 0 / 0
11.01.2018, 18:05
    #39582725
256k
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как сделать чтобы запрос с CASE не вывел ни одной строки?
Щукина Аннаacidophilus,

ну так и пишите это "определенное условие" в кляузе WHERE:

Код: sql
1.
2.
3.
select 1 where case when 2 = 1 then 1 else 2 end = 1; --- не выводит строк

select 1 where case when 1 = 1 then 1 else 2 end = 1; --- выводит одну строку



йез!
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Как сделать чтобы запрос с CASE не вывел ни одной строки? / 7 сообщений из 7, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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