Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2253618
  • 博文数量: 292
  • 博客积分: 10016
  • 博客等级: 中将
  • 技术积分: 3381
  • 用 户 组: 普通用户
  • 注册时间: 2005-11-06 11:26
文章分类

全部博文(292)

文章存档

2011年(1)

2010年(4)

2009年(3)

2008年(6)

2007年(47)

2006年(63)

2005年(168)

分类: Mysql/postgreSQL

2006-01-02 15:14:47

序号的特点是:每次取相应表中的系统当天最大序号,如果当天无记录,则自动生成一个当天序号。

  1.建种子表,这个表用来保存各个表目前已使用到的最大序号

  --种子表

  create table SEED (
  BM varchar(20) not null, --表名
  BH varchar(12) not null, --种子编号
  constraint PK_SEED primary key(BM)
  )
  go
  
  2.当我们建一个新表时,同时把这个表名记录到种子表中,如:

  --向种子中表添加记录

   insert into SEED (BM,BH) values('tablename','200211070000')
  go

  3.在数据库建一存储过程,自动生成新编号,此编号取当天时间,所以许多时候查询某些天的记录时,这个序号非常有用。

  --为参数传递来的某个表自动生成编号

  if exists (select * from sysobjects where name='proc_getbh')
  drop procedure proc_getbh
  go
  create procedure proc_getbh @BM varchar(20)
  as
  declare @BH char(12)
  declare @TODAY char(8)
  begin
  select @TODAY=convert(char(8),getdate(),112)
  select @BH=BH from SEED where
  if @BH is null or left(@BH,8)<>@TODAY
  begin
  select @BH=@TODAY+'0000'
  end
  select @BH=left(@BH,8)+ right('0000' + ltrim(convert(char(4),convert(int,right(@BH,4)))+1),4)
  update SEED set where
  select @BH AS BH
  end

  4.实例如下:

  '对表xxx自动生成新编号

  set rs=conn.execute("proc_getbh @BM='xxx'")
  这样,rs("BH")就是你得到的新编号。

阅读(1606) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~