TSQL order by 子句中排序列的多种写法

简介:

Order by 子句用于对结果进行排序,执行顺序位于select子句之后,排序列有4中写法:

  • column_name
  • column_alias,由于order by子句的执行顺序位于select子句之后,因此,可以使用列的别名;
  • nonnegative integer,用于表示select子句中column的位置,位置从1开始;
  • Column Expression

也可以指定多列排序,每一列只能出现一次,排序的规则是先按照第一列排序,其次按照第二排序,然后按照第三列等排序,依次类推。

1,创建示例表数据

复制代码
CREATE TABLE [dbo].[dt_test]
(
    [id] [int] NULL,
    [code] [int] NULL,
    [name] [varchar](10) NULL
)
复制代码

2,使用column name

select id,code,name 
from dbo.dt_test dt with(nolock)
order by dt.id

3,使用Column Alias,order by子句中能够使用Alias的原因是,SQL Server Engine先执行select 子句,后执行order by 子句。

select id as OrderID,code,name 
from dbo.dt_test dt with(nolock)
order by OrderID

4,使用column order来进行排序,即使用一个正整数来表Select clause中column的顺序来进行排序

select id ,code,name 
from dbo.dt_test dt with(nolock)
order by 1

5,使用column expression来进行排序,执行顺序是先计算Column Expressino的值,然后对查询的结果进行排序。

select id ,code,name 
from dbo.dt_test dt with(nolock)
order by id+code

6,使用column expression来进行排序,执行顺序是先计算Column Expressino的值,然后对查询的结果进行排序。

select id ,code,name 
from dbo.dt_test dt with(nolock)
order by id%3

作者悦光阴
本文版权归作者和博客园所有,欢迎转载,但未经作者同意,必须保留此段声明,且在文章页面醒目位置显示原文连接,否则保留追究法律责任的权利。
分类: SQL Server





本文转自悦光阴博客园博客,原文链接:http://www.cnblogs.com/ljhdo/p/4883198.html,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
SQL
SQL语句两个字段或多个字段同时order by 排序
SQL语句两个字段或多个字段同时order by 排序
40 0
|
3月前
|
SQL 数据库管理
sqlite语句order by两个字段同时排序处理
sqlite语句order by两个字段同时排序处理
21 0
|
4月前
|
SQL 数据库管理
SQL基础题----基本的SELECT语句、order by排序
SQL基础题----基本的SELECT语句 ambiguous 模糊
178 1
|
7月前
可以使用 UNION 或者 UNION ALL 来合并多个 SELECT 语句的结果
可以使用 UNION 或者 UNION ALL 来合并多个 SELECT 语句的结果
69 7
|
8月前
数据查询语句:包括SELECT语句、WHERE子句、GROUP BY子句、HAVING子句、ORDER BY子句等,用于从数据表中检索数据。
数据查询语句:包括SELECT语句、WHERE子句、GROUP BY子句、HAVING子句、ORDER BY子句等,用于从数据表中检索数据。
25 1
|
11月前
ORDER BY子句
ORDER BY子句
35 0
|
SQL
SQL语句之排序 —— ORDER BY
SQL语句之排序 —— ORDER BY
812 0
SQL语句之排序 —— ORDER BY
SELECT 语句中的 子查询(Sub Query)
SELECT 语句中的子查询 子查询(Sub Query)或者说内查询(Inner Query),也可以称作嵌套查询(Nested Query),是一种嵌套在其他 SQL 查询的 WHERE 子句中的查询。
1217 0
|
关系型数据库 MySQL 数据库
select distinct去掉重复查询结果|学习笔记
快速学习select distinct去掉重复查询结果
222 0