在临时表中插入时无法工作的顺序

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)

Gor*_*off 5

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)

将使用聚簇索引按顺序返回结果。无需分类。