在临时表中插入时不按顺序排序

时间:2015-11-14 13:03:05

标签: 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

3 个答案:

答案 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)