gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 15:58:54 24 4
gpt4 key购买 nike

我有一个查询,当我在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

最佳答案

SQL表表示无序集。有什么不清楚的地方吗?

当您从表中使用SELECT时,结果是无序的。一个异常(exception)是在外部查询中使用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;

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

关于sql - 在临时表中插入时无法工作的顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33708690/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com