例如,如果要根据列1填充列2,可以使用如下 SQL 语句:
SELECT
列1,ROW_NUMBER() OVER (PARTITION BY 列1 ORDER BY 列1) 列2FROM 表A
其中,ROW_NUMBER()是一个窗口函数,它根据给定的分组条件(在本例中为列1),为每一行生成一个唯一的行号。
结果应该类似于下面这样:
列1 列2
aa1
aa1
bb1
cc1
注意,由于没有给定排序条件,因此行号的生成顺序是不确定的。如果要按照列1的值的字母顺序为每一行生成行号,可以将上面的语句更改为:
SELECT
列1,ROW_NUMBER() OVER (PARTITION BY 列1 ORDER BY 列1) 列2FROM 表AORDER BY 列1
结果应该类似于下面这样:
列1 列2
aa1
aa1
bb2
cc3
希望这些信息能对你有所帮助。
现有两种方法解决,供参考:1、SELECT
IDENTITY(INT,1,1)
AS
序号,
avge
FROM
Table1
2、SELECT
IDENTITY(INT,1,1)
AS
序号,
avge
INTO
#temp1
FROM
Table1
SELECT
*
FROM
#temp1
DROP
TABLE
#temp1
给查询出的SQL记录添加序号列,解决方法有以下两种
第一:
select
ROW_NUMBER()
OVER
(ORDER
BY
a.字段
ASC)
AS
XUHAO,a.*
from
table
a1
(table
为表名,字段为表a中的字段名)
第二:
select
RANK()
OVER
(ORDER
BY
a.字段
ASC)
AS
XUHAO,a.*
from
table
a1
(table
为表名,字段为表a中的字段名)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)