Ali*_*had 2 sql sql-server sql-server-2012
我有一个查询,当我在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
Run Code Online (Sandbox Code Playgroud)
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
);
Run Code Online (Sandbox Code Playgroud)
然后,当您这样做时:
insert into #temp(SKU, QtyRec, Expiry, Rec)
select SKU, QtyRec, Expiry, Rec
from @Data
order by id;
Run Code Online (Sandbox Code Playgroud)
群集中的主键输入#temp必须按所指定的顺序进行order by。然后查询:
select *
from #temp
order by id;
Run Code Online (Sandbox Code Playgroud)
将使用聚簇索引按顺序返回结果。无需分类。