在语句的情况下按列号对表进行排序

Ordering table by column number in case when statement(在语句的情况下按列号对表进行排序)
本文介绍了在语句的情况下按列号对表进行排序的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

是否可以在语句的情况下使用列号对表进行排序?这是代码

Is it possible to order table with column number in case when statement? Here is the code

;WITH
    Table1 AS (....),
    Table2 AS (....)

INSERT INTO #temp
SELECT TOP 50 
    one.id,
    one.sales,
    two.count,
    one.sales * two.count as 'Volume %'        
FROM Table1 one,
INNER JOIN Table2 two on one.id = two.id
ORDER BY 
    CASE  @order
        WHEN 1 THEN 
            7             ---Column number here since [Volume %] giving me an error
        WHEN 2 THEN
            10            ---Column number
        END
    DESC

推荐答案

我做了一些测试并了解到,虽然直接 ORDER BY 可以引用列别名(即使是带有空格字符的别名),但 ORDER BY 中的 CASE 表达式不能.我从未在任何地方看到过这种记录,但我自己测试过.

I have done some testing and learned that while a straight ORDER BY can reference column aliases (even those with space characters), a CASE expression in an ORDER BY cannot. I've never seen this documented anywhere, but I have tested it myself.

别名中有特殊字符并不重要.如果你只做了:

It doesn't matter that you have a special character in your alias. If you had only done:

one.sales * two.count as Volume   

您仍然会收到以下错误:

You would still get an error with:

  ORDER BY CASE @order
   WHEN 1 THEN Volume

我怀疑这与您不能使用列号的原因相同.

And I suspect that's the same reason why you can't use column numbers.

作为解决此问题的可靠方法,我的建议是:

My suggestion as a sure-fire way to fix this is:

  ORDER BY CASE @order
   WHEN 1 THEN  one.sales * two.count

这篇关于在语句的情况下按列号对表进行排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Error casting varchar containing a number expressed in scientific notation to decimal(将包含以科学记数法表示的数字的 varchar 转换为十进制时出错)
Calculate cumulative product value(计算累积产品价值)
SQL Server loop for changing multiple values of different users(用于更改不同用户的多个值的 SQL Server 循环)
SQL Server 2008: Can a multi-statement UDF return a UDT?(SQL Server 2008:多语句 UDF 能否返回 UDT?)
Merge columns in sql(合并sql中的列)
SQL Column is invalid in ORDER BY, not contained in aggregate or GROUP BY(SQL 列在 ORDER BY 中无效,未包含在聚合或 GROUP BY 中)