首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

怎么根据同天生成流水号

2013-02-03 
如何根据同天生成流水号T1时间姓名性别2012-01-01A男2012-01-01B男2012-01-01C男2012-01-01D男2012-01-02E

如何根据同天生成流水号
T1
时间           姓名     性别
2012-01-01    A        男
2012-01-01    B        男
2012-01-01    C        男
2012-01-01    D        男
2012-01-02    E        男
2012-01-02    F        男
2012-01-03    G        男
2012-01-03    H        男
2012-01-04    I        男
结果
时间           姓名     性别      流水号
2012-01-01    A        男        1
2012-01-01    B        男        2
2012-01-01    C        男        3
2012-01-01    D        男        4
2012-01-02    E        男        1
2012-01-02    F        男        2
2012-01-03    G        男        1
2012-01-03    H        男        2
2012-01-04    I        男        1
根据时间按每天生成当天的流水号
[解决办法]


--用姓名好像不太贴切,最好有id一类的有序的能标识的列替换到order by这里
select *,row_number() over(partition by 时间 order by 姓名)as 流水号 from T1

[解决办法]

select *,
    序号=(select count(*) from tb where 时间 = t.时间 and 姓名 <= t.姓名)
from tb t

热点排行