我有一个查询,当我在SQL Server 2012中执行它时,ORDER BY
子句不起作用。请帮帮我。问候。
DECLARE @Data table (Id int identity(1,1), SKU varchar(10), QtyRec int,Expiry date,Rec date)
DECLARE @Qty int = 20
INSERT @Data
VALUES
('001A', 5 ,'2017-01-15','2015-11-14'),
('001A', 8 ,'2017-01-10','2015-11-14'),
('001A', 6 ,'2015-12-15','2015-11-15'),
('001A', 25,'2016-01-01','2015-11-16'),
('001A', 9 ,'2015-12-20','2015-11-17');
SELECT *
INTO #temp
FROM @Data
ORDER BY Id DESC
SELECT *
FROM #temp
答案 0 :(得分:3)
SQL表代表无序集。有什么不清楚的吗?
当您从表中SELECT
时,结果无序。一个例外是在外部查询中使用ORDER BY
时。因此,请添加ORDER BY
,结果将按顺序排列。
编辑:
您可以通过引入群集主键来消除排序的工作。
create table #temp (
Id int identity(1,1) primary key clustered,
SKU varchar(10),
QtyRec int,
Expiry date,
Rec date
);
然后当你这样做:
insert into #temp(SKU, QtyRec, Expiry, Rec)
select SKU, QtyRec, Expiry, Rec
from @Data
order by id;
#temp
中的群集主键保证按order by
指定的顺序排列。然后查询:
select *
from #temp
order by id;
将使用聚簇索引按顺序返回结果。不需要排序。
答案 1 :(得分:1)
SELECT ... INTO
子句将帮助您达到预期的输出。我通常以这种方式使用临时表以及使用ROW_NUMBER()
函数的具有行号的列。它会自动将所选行排序到临时表。或更简单地说,您可以使用ORDER BY
子句。
答案 2 :(得分:-1)
您可以使用force选项强制使用订单执行。下面是一个示例。
create table #temp (
Id int,
SKU varchar(10),
QtyRec int,
Expiry date,
Rec date
);
insert into #temp(SKU, QtyRec, Expiry, Rec)
select SKU, QtyRec, Expiry, Rec
from @Data
order by id option (force order)