Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Сортировка выдаваемого запроса / 13 сообщений из 13, страница 1 из 1
21.09.2016, 11:41:53
    #39312555
Lilzen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Всем здравствуйте, ребят возникла тут у меня такая проблема... Пытаюсь написать запросы в запросах мне в исходном виде нужно получить таблицу которая считает количество строк в запросах и выдавала их строка за строкой. Но проблема в том что при объединении запросов параметром union разпологает запросы в хаотичном порядке. Подскажите пожалуйста как сделать так что бы сначала как в запросе и написано сделать первой стракой 1 запрос потом 2 и при добавлении ещё запросов через union они все шли по порядку сверху вниз

SELECT DISTINCT
(SELECT COUNT(*)
FROM F116
WHERE R_F10=3),
(SELECT COUNT (*)
FROM F116
WHERE R_F10=2)
FROM F116

UNION

SELECT DISTINCT
(SELECT COUNT(*)
FROM F116
WHERE R_F10=30),
(SELECT COUNT (*)
FROM F116
WHERE R_F10=20)
FROM F116;
...
Рейтинг: 0 / 0
21.09.2016, 11:45:19
    #39312557
dmdmdm
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Добавить поле с нужной сортировкой, сортировать по нему.
...
Рейтинг: 0 / 0
21.09.2016, 11:46:04
    #39312559
Сортировка выдаваемого запроса
Lilzen,

сделать секции нумерованными:
select distinct * from (
Select 1 as section_num, bla-bla-bla from ...
union
Select 2 as section_num, bla-bla-bla from ...)
order by section_num
...
Рейтинг: 0 / 0
21.09.2016, 11:55:27
    #39312573
Elic
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Советчики, а надо было лишь добавить ALL.
...
Рейтинг: 0 / 0
21.09.2016, 11:57:01
    #39312575
AnSi_Sr
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
SELECT F116.R_F10 AS uvalue, COUNT(1) as ncount
  FROM F116
WHERE F116 IN (3, 2, ...)
GROUP BY F116.R_F10
ORDER BY
  CASE F116.R_F10
    WHEN 3 THEN 1 -- order by
    WHEN 2 THEN 2
    ...
    ELSE NULL
  END
NULLS LAST
...
Рейтинг: 0 / 0
21.09.2016, 12:33:11
    #39312621
Lilzen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
19691091

А где поставить?! Пример может кто нибудь кинуть?!
...
Рейтинг: 0 / 0
21.09.2016, 12:36:25
    #39312626
dimyaz
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
ElicСоветчики, а надо было лишь добавить ALL.

особенно
Код: plsql
1.
select distinct
...
Рейтинг: 0 / 0
21.09.2016, 12:40:13
    #39312629
Сортировка выдаваемого запроса
Lilzen 19691091

А где поставить?! Пример может кто нибудь кинуть?! Тут было
...
Рейтинг: 0 / 0
21.09.2016, 12:42:17
    #39312631
dmdmdm
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
with t as ( select 10 n from dual union all
            select 5 n from dual union all
            select 15 n from dual union all
            select 25 n from dual union all
            select 3 n from dual union all
            select 7 n from dual
          )


select 1 sort, t.n from t where n <= 10

union all

select 2 sort, t.n from t where n > 10

order by sort, n



order нужен, если вам еще какая-то сортировка нужна, кроме секционной
а так достаточно union all
...
Рейтинг: 0 / 0
21.09.2016, 12:43:21
    #39312632
Lilzen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Пошутлятор,

Не открывается
...
Рейтинг: 0 / 0
21.09.2016, 12:44:18
    #39312634
Сортировка выдаваемого запроса
dmdmdmа так достаточно union allсчас он тебя спросит, почему в результате выборки появились дубликаты.
...
Рейтинг: 0 / 0
21.09.2016, 12:45:31
    #39312637
Egoр
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Lilzen,

Однако. Попробуйте так:
Код: plsql
1.
2.
3.
4.
5.
6.
7.
SELECT
   sum(case substr(R_F10, 1, 1) when '3' then 1 end) as sum_3,
   sum(case substr(R_F10, 1, 1) when '2' then 1 end) as sum_2
FROM F116
where R_F10 in (2,3,20,30)
group by length(R_F10)
order by length(R_F10) 
...
Рейтинг: 0 / 0
21.09.2016, 12:47:16
    #39312638
Lilzen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сортировка выдаваемого запроса
Спасибо огромное сработало
...
Рейтинг: 0 / 0
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Сортировка выдаваемого запроса / 13 сообщений из 13, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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