表结构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) 要达到这样主键列的要求,请问这个表定义语句应该怎么写呢?
并且这个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) 要达到这样主键列的要求,请问这个表定义语句应该怎么写呢?
解决方案 »
- sqlserver datetime部分转换格式
- sql server2008 windows身份登陆不了
- 如何在查询分析器中用语句把符合条件的记录输出到一个文件
- 关于NVARCHAR(4000) 字符串过少的问题
- 请教: 如何利用sql server 2000 保护数据库中的表,并针对表设置访问权限
- sql server 数据文件与数据表的关系(菜鸟问题)
- 日期格式与本地环境
- sqlserver从控制台中删除服务器后怎么恢复
- 怎么样不在存储过程中创建临时表,也就是说在语句中创建?在线等待,急!!!
- 查询时能否得到每一行的行号(标识第几行)?
- 求助,问一句简单的aql语句!
- 使用SMO如何删除主键?200分 见内
userid列应该是由 年份+日期+'00'+x组成一个字符串如调用ff(getdate(),3)函数时,convert(char(8),@t,112)生成20070530,replicate('0',3-len(@id))+rtrim(@id)生成流水号003,最后生成的结果就是20070530003可是用它作主键应该怎么写表定义呢?
就可以了
[userid] [char] (11) COLLATE Chinese_PRC_CI_AS NOT NULL
) ON [PRIMARY]
GOALTER TABLE [dbo].[T] WITH NOCHECK ADD
CONSTRAINT [PK_T] PRIMARY KEY CLUSTERED
(
[userid]
) ON [PRIMARY]
GO
create table test(id varchar(18), --流水号,日期(8位)+时间(4位)+流水号(4位)
name varchar(10) --其他字段
)go
--创建生成流水号的触发器
create trigger t_insert on test
INSTEAD OF insert
as
declare @id varchar(18),@id1 int,@head varchar(12)
select * into #tb from inserted
set @head=convert(varchar,getdate(),112)+replace(convert(varchar(5),getdate(),108),':','')
select @id=max(id) from test where id like @head+'%'
if @id is null
set @id1=0
else
set @id1=cast(substring(@id,13,4) as int)
update #tb set @id1=@id1+1
,id=@head+right('0000'+cast(@id1 as varchar),4)
insert into test select * from #tb
go
--插入数据,进行测试
insert into test(name)
select 'aa'
union all select 'bb'
union all select 'cc'--修改系统时间,再插入数据测试一次
insert into test(name)
select 'aa'
union all select 'bb'
union all select 'cc'--显示测试结果
select * from test
--删除测试环境
drop table test/*--测试结果
id name
------------------ ----------
2004022720430001 aa
2004022720430002 bb
2004022720430003 cc
2004022720430004 aa
2004022720430005 bb
2004022720430006 cc(所影响的行数为 6 行)
--*/