Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/15: Рейтинг темы: голосов - 15, средняя оценка - 4.73
0 / 0 / 1
Регистрация: 05.07.2016
Сообщений: 41

Сортировка запросов с union

15.07.2016, 07:09. Показов 3218. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть четыре запроса, которые объединены union.
T-SQL
1
2
3
4
5
6
7
8
Select * from table where id=1
union
Select * from table where id=2
union
Select * from table where id=3
union
Select * from table where id=4
order by text
выдает ошибку, что так делать нельзя.
Подскажите, пожалуйста, а как правильно написать запрос, чтобы MSSQL перстала ругаться и все четыре запроса отсортировались.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.07.2016, 07:09
Ответы с готовыми решениями:

Сортировка запросов с UNION ALL
Использую двойной запрос из двух таблиц, (SELECT 'Студент' AS 'Статус', SFAM FROM Students WHERE SFAM between 'К%' and 'С%' ) ...

Оператор UNION
С помощью оператор UNION, мне необходимо два столбца с одной таблицы перенести в другую,т.е первая таблица "ЧИТАТЕЛИ", в ней...

Упростить UNION
Здравствуйте! Такой вопрос: есть таблица параметров объекта ObjPars (IDobj, old_val1, new_val1,...,old_valN, new_valN). Как из этой...

5
шапоклякистка 8-го дня
 Аватар для texnik-san
3681 / 2241 / 391
Регистрация: 26.06.2015
Сообщений: 4,647
Записей в блоге: 1
15.07.2016, 12:04
Поле, по которому выполняется сортировка, должно быть в явном виде перечислено в select.

Добавлено через 15 минут
Ну и это.. Если запросы в самом деле такие, как у вас написано, то тут UNION не нужен вообще, тут

SQL
1
2
SELECT * FROM TABLE WHERE id IN (1,2,3,4)
ORDER BY text
1
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
15.07.2016, 12:11
Цитата Сообщение от spu164 Посмотреть сообщение
выдает ошибку, что так делать нельзя.
А текст ошибки, наверное, содержит нецензурные выражения и поэтому его нельзя опубликовать?
Цитата Сообщение от spu164 Посмотреть сообщение
Подскажите, пожалуйста, а как правильно написать запрос
Запрос написан синтаксически верно, а семантически безграмотно. Можно переписать так
T-SQL
1
select distinct * from table where id in (1, 2, 3, 4) order by text;
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
15.07.2016, 12:22
Цитата Сообщение от texnik-san Посмотреть сообщение
Поле, по которому выполняется сортировка, должно быть в явном виде перечислено в select.
а пацаны-то и не знают...
магия?
SQL
1
2
3
4
5
6
7
8
9
10
11
WITH cte(a,b,c) AS
  (
    SELECT 1,2,3
  UNION ALL 
  SELECT 2,4,5
  UNION ALL
  SELECT 4,8,10
  
  )
  SELECT a,b FROM cte
  ORDER BY c DESC
Добавлено через 2 минуты
а, ну да. Поспешил. Хотя бы в одном select нужно поименовать поля
1
0 / 0 / 1
Регистрация: 05.07.2016
Сообщений: 41
15.07.2016, 13:42  [ТС]
получилось отсортировать, написав номер столбца, а не его название
T-SQL
1
order by 1,13
Спасибо за ответы.
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
16.07.2016, 19:33
Цитата Сообщение от pincet Посмотреть сообщение
а, ну да. Поспешил. Хотя бы в одном select нужно поименовать поля
Они все уже поименованы в объявлении CTE (a,b,c).
Так что всё в порядке
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.07.2016, 19:33
Помогаю со студенческими работами здесь

Предложение union
Нужно вывести информацию о книгах с указанием разрешенного срока использования в зависимости от количества имеющихся экземпляров: Кол-во...

Insert и Union
Кто знает, скажите пожалуйста - почему не работает? (б.д. PARADOX) insert into ":alias:Table1.db" select * from...

Возможен ли такой Union
Здравствуйте, ребята! Помогите, пожалуйста, справиться с таким запросом declare @t_all table(a varchar(10), b varchar(10), Summ int) ...

Конфликт union и order by
есть такое задание(картинка во вложение), после задания идет правильный вывод решения. вроде все просто, но получается что union...

Ошибка в запросе с UNION
begin yearvalue1:=LabeledEdit2.Text; begin with ADOQuery2 do begin Close; SQL.Clear; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru