主题:创建时间流水帐号列的表问题
表结构t里有一列userid,它是由年份+日期+'00'+x组成一个字符串,其中x是自增的,从0开始.例如第一条记录
最后三位为000,第十条记录最后三位为010.
并且这个userid列是表t的主键列,请问怎么创建这个表?
我写了一个函数可以用来生成这个字符串,但还是不知道怎样创建这个主键列,这个函数用在表定义中总是出错.
--函数定义
create function ff(@t datetime,@id int) returns char(11)
as begin return convert(char(8),@t,112)+replicate('0',3-len(@id))+rtrim(@id) end
--单独调用函数,结果符合要求
select dbo.ff(getdate(),3)
要达到这样主键列的要求,请问这个表定义语句应该怎么写呢?(不用触发器)
最后三位为000,第十条记录最后三位为010.
并且这个userid列是表t的主键列,请问怎么创建这个表?
我写了一个函数可以用来生成这个字符串,但还是不知道怎样创建这个主键列,这个函数用在表定义中总是出错.
--函数定义
create function ff(@t datetime,@id int) returns char(11)
as begin return convert(char(8),@t,112)+replicate('0',3-len(@id))+rtrim(@id) end
--单独调用函数,结果符合要求
select dbo.ff(getdate(),3)
要达到这样主键列的要求,请问这个表定义语句应该怎么写呢?(不用触发器)