1

我有以下 SQL,Incorrect syntax near keyword 'ORDER'当我尝试执行它时它给了我:

SELECT COUNT(*) AS ID 
FROM Employees i
  INNER JOIN #WeightedIDs w
  ON (i.ID = w.ID)
WHERE (i.DepartmentID = 10 and i.ShiftID = 2)

UNION ALL

SELECT i.ID FROM Employees i
  INNER JOIN #WeightedIDs w
  ON (i.ID = w.ID)
WHERE (i.DepartmentID = 10 and i.ShiftID = 2)
ORDER BY w.[Weight] ASC

我应该如何解决它?

更新:

这就是我真正想要完成的事情。我有一个 SPROC,它根据一堆不同的条件动态生成查询。它还构建了一个临时表,其中包含 ID 和与这些 ID 关联的权重,因此我希望结果按此排序。生成查询后,我想获取计数以及在列表中返回的 id。

4

2 回答 2

5

在联合中,您只能订购完整结果,而不是部分结果,因为订购子选择没有意义 - 它是一个关系/表,并且它们(根据定义)未排序。

如果您希望对整体结果进行排序,您可以添加一个ORDER BY 1 ASC以按第一(也是唯一)列排序。如果您希望第一部分的所有行都排在第二部分之前并按重量对第二部分进行排序,您可以执行以下操作:

select id
from
(
  SELECT COUNT(*) AS ID, 
         0 as sort_column
  FROM Employees i
    INNER JOIN #WeightedIDs w
    ON (i.ID = w.ID)
  WHERE (i.DepartmentID = 10 and i.ShiftID = 2)

  UNION ALL

  SELECT i.ID, 
         x.[Weight] 
  FROM Employees i
    INNER JOIN #WeightedIDs w
    ON (i.ID = w.ID)
  WHERE (i.DepartmentID = 10 and i.ShiftID = 2)
) x
order by sort_column

这假定 的值x.weight大于零。如果不是,您需要在联合的第一部分使用不同的(较低的)值。

于 2012-08-02T17:34:49.013 回答
1

如果将 ORDER BY 移动到 UNION 中的第一个 SELECT,它将对整个结果集进行排序。但是,它必须在第一个 SELECT 上,其他任何地方都会导致您看到的错误。

于 2012-08-02T17:47:27.010 回答