SQL额外增加自动递增序号

来源:互联网 发布:英语听力考试软件 编辑:程序博客网 时间:2024/09/21 06:36
图表1
如果数据表本身并不内含自动地增编号的字段时,要怎么做才能够让SELECT查询结果如图表1所示,额外增加自动递增序号呢?我们提供下列五种方法供您参考:
USE北风贸易;
GO

/*方法一*/

SELECT序号=(SELECT COUNT(客户编号)FROM 客户AS LiMing
                   WHERE LiMing.客户编号<= Chang.客户编号),
      客户编号,公司名称
FROM客户AS Chang ORDER BY 1;
GO

/*方法二:使用SQL Server 2005独有的RANK() OVER ()语法*/
SELECTRANK() OVER (ORDER BY 客户编号 DESC) AS序号,
        客户编号,公司名称
FROM客户;
GO

/*方法三*/
SELECT序号=COUNT(*), LiMing.客户编号, LiMing.公司名称
  FROM 客户AS LiMing, 客户AS Chang
  WHERE LiMing.客户编号>= Chang.客户编号
  GROUP BY LiMing.客户编号, LiMing.公司名称
  ORDER BY 序号;
GO

/*方法四
建立一个「自动编号」的字段,然后将数据新增至一个区域性暂存数据表,
然后由该区域性暂存数据表中,将数据选取出来,最后删除该区域性暂存数据表
*/
SELECT序号= IDENTITY(INT,1,1),管道,程序语言,讲师,资历
INTO #LiMing
FROM问券调查一;
GO
SELECT* FROM #LiMing;
GO
DROPTABLE #LiMing;
GO

/*
方法五
使用 SQL Server 2005独有的ROW_NUMBER() OVER ()语法
搭配 CTE(一般数据表表达式,就是 WITH那段语法)选取序号2 ~ 4的数据
*/
WITH排序后的图书AS
(SELECT ROW_NUMBER()OVER (ORDERBY 客户编号DESC) AS 序号,
 客户编号,公司名称
  FROM 客户)
SELECT* FROM 排序后的图书
WHERE序号BETWEEN 2 AND 4;
GO
0 0
原创粉丝点击