急急!求购单号自动形成的触发器???在线待待!

dzy983 2004-07-10 03:55:34
例如有表tab(a varchar(100),b varchar(100))想每次向这张表插入记录时自动形成单号(sj+当前日期+五位流水号):求购instead of 触发器如何实现。

表内容如下:
a b
sj-2004-06-06-00001 324324
sj-2004-06-06-00002 33343
sj-2004-06-07-00001 22222
sj-2004-09-09-00001 24324
例如:
insert into tab values('sj','2222')执行自动得到单号然后把记录插入到表中去;记录内容应该为:sj-2004-07-10-00001 2222
在线等待!高手指教!!!!!!!!
...全文
235 21 打赏 收藏 转发到动态 举报
写回复
用AI写文章
21 条回复
切换为时间正序
请发表友善的回复…
发表回复
dzy983 2004-07-12
  • 打赏
  • 举报
回复
朱二的如果遇到进行批量进行插入时就不行啦!
dzy983 2004-07-12
  • 打赏
  • 举报
回复
朱二的处理不了我说的这些情况!
dzy983 2004-07-12
  • 打赏
  • 举报
回复
to: lenghuazhang(未名)
update tab set a=rtrim(@astr)+'-00001'你这句把所有记录都更新啦!
frankwong 2004-07-12
  • 打赏
  • 举报
回复
邹建的好像复杂了点,朱二的够用了
dzy983 2004-07-12
  • 打赏
  • 举报
回复
to: zjcxc(邹建)
你可能水平太高!我是sql初学者,你写的我看不懂!
dzy983 2004-07-12
  • 打赏
  • 举报
回复
to: lenghuazhang(未名)
你试过这种情况吗:
insert into tab
select 'sj','djowsd'
union all
select 'sj','12345'

dzy983 2004-07-12
  • 打赏
  • 举报
回复
to:lenghuazhang(未名)
你为什么不用instead of insert触发器呢?
lenghuazhang 2004-07-11
  • 打赏
  • 举报
回复
create trigger fortable on tab for insert
as
declare @astr varchar(100),@bstr varchar(100),@cstr varchar(100)
declare @dstr varchar(100),@tempstr varchar(100),@e int
select @astr=convert(varchar(20),getdate(),112)
select @bstr=''
select @bstr=@bstr+'-'+left(@astr,4)+'-'+substring(@astr,5,2)+'-'+substring (@astr,7,2)
select @astr=a from inserted
select @astr=@astr+@bstr
select @cstr=@astr+'%'
if not exists(select * from tab where a like @cstr)
update tab set a=rtrim(@astr)+'-00001'
else
begin
select @dstr=max(a) from tab where a like @cstr
select @e=cast(right(rtrim(@dstr),5) as int)
select @tempstr=case
when len(@e)=1 then '0000'+cast(@e as varchar(1))
when len(@e)=2 then '000'+cast(@e as varchar(2))
when len(@e)=1 then '00'+cast(@e as varchar(3))
when len(@e)=1 then '0'+cast(@e as varchar(4))
else cast(@e as varchar(5))
end
update tab set a=rtrim(@astr)+'-'+@tempstr where a in(select a from inserted)
end
go

试试我的,在我的机子上完全通过测试.
假设表中原有如下数据.
a b
'sj-2004-07-10-00103','djosw'
'sj-2004-07-10-00206','djows'
'sdwj-2004-06-05-00503','djows'
'dfs-2004-07-10-00023','djowsw'

插入测试:
insert into tab
select 'sj','djowsd'
union
select 'sdwj','12345'
union
select 'dfs','djwosw'
union
select 'asdf','23451'

得出的结果为
a b
'sj-2004-07-10-00103','djosw'
'sj-2004-07-10-00206','djows'
'sj-2004-07-10-00207','djowsd'
'sdwj-2004-06-05-00503','djows'
'sdwj-2004-07-10-00001','12345'
'dfs-2004-07-10-00023','djowsw'
'dfs-2004-07-10-00024','djwose'
'asdf-2004-07-10-00001','23451'
8536105 2004-07-11
  • 打赏
  • 举报
回复
瑞星公司的单据流水号生成存储过程

CREATE procedure dbo.GetDOCNO(@LEVEL1 tinyint, @DOCNO char(12) output) as
begin
--(2位凭证)XX(1位年)Y(2位月)MM(2位日)DD(2位店铺00-FF)XX(3位流水)001
--{@Level1 一级凭证的类型}
--{@DocNo 凭证号码的返回值}
--生成凭证的单据号码
declare @SECTION varchar(80)
declare @CODE varchar(80)
declare @NAME varchar(80)
declare @SNO varchar(4)
declare @FisrtC char
declare @IsInc bit
declare @NetCode int

begin tran

select @NetCode = dbo.GetIntVar('系统参数','网点编号',0)
select @SECTION = '单据流水号', @CODE = '[' + right('000'+convert(varchar(3), @LEVEL1), 2) + ']' + dbo.GetEBKDSC(@LEVEL1 * 1000000)
if not exists(select 1 from syscfg where [section]= @SECTION and [code] = @CODE)
begin
select @NAME = dbo.GetEBKDSC(@LEVEL1 * 1000000) + '流水号'
insert into syscfg ([section], code, [name], value, issystem, tpid, editformat, sectionname, directinput)
values (@SECTION, @CODE, @NAME, '000', 1, 1, '', @SECTION, 0)
end

select @SNO = Value from SYSCFG where [section] = @SECTION and [code] = @CODE
if len(@SNO) < 3
select @SNO = right('000'+@SNO,3)

if right(@SNO,3) = '999'
select @IsInc = 1
else
select @IsInc = 0

select @SNO = right('000'+convert(varchar(4),cast(right(@SNO,3) as int)+1),3)

update syscfg set value = @SNO where [section] = @SECTION and [code] = @CODE

commit tran

select @DOCNO = right('00' + convert(varchar(3), @LEVEL1), 2) +
right(convert(varchar(8), getdate(), 112), 5) +
right('00'+ dbo.SysInt2Hex(@NetCode), 2) +
right('000'+ @SNO, 3)
select 1
end
lovvver 2004-07-10
  • 打赏
  • 举报
回复
不知你用的什么开发语言,如果是用中间键的话,可以写一个函数来实现.
lovvver 2004-07-10
  • 打赏
  • 举报
回复
对于你上面的问题,sql 语句是直接嵌入的话,不必要用instead of触发器来做,可以直接写一个函数,在插入的时候调用函数直接插入.
该表最好多加一个单号的字段.
laker_tmj 2004-07-10
  • 打赏
  • 举报
回复
up
zjcxc 元老 2004-07-10
  • 打赏
  • 举报
回复
用1000001加的目的是生成格式化的编码方便,即可以直接用right(@a,5),就得到形如:
00001,00002这样的编号

zjcxc 元老 2004-07-10
  • 打赏
  • 举报
回复
--触发器少写了一个-,编码格式有点问题

create trigger tr_insert on tab
instead of insert
as
declare @dt varchar(10)
set @dt='-'+convert(varchar(10),getdate(),120)

select * into #t
from inserted a join(
select gid_new=b.a,sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
from tab a
right join inserted b on charindex(b.a+@dt,a.a)=1
group by b.a
)b on a.a=b.gid_new
order by b.gid_new

declare @nid varchar(100),@a int
update #t set @a=case @nid when gid_new then @a+1 else sid_new end
,a=gid_new+@dt+'-'+right(@a,5) --这里少了一个-
,@nid=gid_new

insert tab select a,b from #t
go
dzy983 2004-07-10
  • 打赏
  • 举报
回复
我sql初学者!能不能把这一段解释一下:
select * into #t
from inserted a join(
select gid_new=b.a,sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
from tab a
right join inserted b on charindex(b.a+@dt,a.a)=1
group by b.a
)b on a.a=b.gid_new
order by b.gid_new
dzy983 2004-07-10
  • 打赏
  • 举报
回复
to: zjcxc(邹建) 大哥
sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
为什么用1000001加是什么意思!你能把思想给我说说吗!你sql我有点看不懂!我是sql初学者!知道你能不能帮解释一下!万分感谢!!!!我知道在这儿你很历害!
dzy983 2004-07-10
  • 打赏
  • 举报
回复
别外我有可能存在一次批量插入多条记录!也就是可能触发器一次生成多个单号!
别外还一种情况:
insert into tab ('ww','eeee')要得到插入如下记录:
ww-2004-07-10-00001 eeee
前面的"sj"与"ww"是动态的是不确定的!
zjcxc 元老 2004-07-10
  • 打赏
  • 举报
回复
--示例

--表
create table tab(a varchar(100),b varchar(100))
go

--触发器
create trigger tr_insert on tab
instead of insert
as
declare @dt varchar(10)
set @dt='-'+convert(varchar(10),getdate(),120)

select * into #t
from inserted a join(
select gid_new=b.a,sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
from tab a
right join inserted b on charindex(b.a+@dt,a.a)=1
group by b.a
)b on a.a=b.gid_new
order by b.gid_new

declare @nid varchar(100),@a int
update #t set @a=case @nid when gid_new then @a+1 else sid_new end
,a=gid_new+@dt+right(@a,5)
,@nid=gid_new

insert tab select a,b from #t
go

--插入数据
insert tab values('sj','2222')
insert tab select 'sj','324324'
union all select 'sj','33343'
union all select 'dj','33343'
union all select 'dj','24324'
union all select 'sj','24234'

--显示插入结果
select * from tab order by a
go

--删除测试
drop table tab

/*--测试结果

a b
------------------------- --------
dj-2004-07-100001 33343
dj-2004-07-100002 24324
sj-2004-07-100001 2222
sj-2004-07-100002 324324
sj-2004-07-100003 33343
sj-2004-07-100004 24234

(所影响的行数为 6 行)
--*/
zjcxc 元老 2004-07-10
  • 打赏
  • 举报
回复
--触发器
create trigger tr_insert on tab
instead of insert
as
declare @dt varchar(10)
set @dt='-'+convert(varchar(10),getdate(),120)

select * into #t
from inserted a join(
select gid_new=b.a,sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
from tab a
right join inserted b on charindex(b.a+@dt,a.a)=1
group by b.a
)b on a.a=b.gid_new
order by b.gid_new

declare @nid varchar(100),@a int
update #t set @a=case @nid when gid_new then @a+1 else sid_new end
,a=gid_new+@dt+right(@a,5)
,@nid=gid_new

insert tab select a,b from #t
go
netcoder 2004-07-10
  • 打赏
  • 举报
回复
--测试一
create table tab(a varchar(100),b varchar(100))
go
create trigger trg_test on tab
instead of insert
as
declare @s varchar(21)
set @s=cast((select isnull(max(cast(right(a,5) as int)),0)+1 from tab)as varchar)
set @s=right('0000' + @s,5)
set @s='-' + convert(varchar(10),getdate(),120)+ '-' + @s
insert tab
select a+@s, b from inserted

go

insert into tab values('sj','dd')
insert into tab values('sj','dd')
select * from tab

drop table tab

--结果
/*--
(所影响的行数为 1 行)

a b
--------------------- ----
sj-2004-07-10-00001 dd
sj-2004-07-10-00002 dd

(所影响的行数为 2 行)
--*/
加载更多回复(1)
内容简介   《google android sdk开发范例大全(第3版)》在上一版的基础上,以android手机应用程序开发(采用android sdk 2.3.3)为主题,超过200多个范例全面且深度地整合了手机、网络及服务等多个开发领域,为读者提高程序设计能力提供了很大的帮助。    全书共分11章,主要以范例集的方式来讲述android的知识点,详细介绍了开发android的人机交互界面、android常用的开发控件、android手机收发短信等通信服务、开发android手机的自动服务功能和娱乐多媒体功能以及整合android与google强大的网络服务等内容。随书光盘中包括了所有范例的程序代码。    《google android sdk开发范例大全(第3版)》继承前两版由浅入深的方式,范例总数由原先的160多个增加到了200多个,在用户交互界面、手机控件、交互式通信服务、手机自助服务、娱乐多媒体等方面均增加了相应的范例来介绍新的开发技术,特别是新增加了第11章来专门介绍html5技术在android移动设备里的应用,相信当下两个热门技术的交汇会碰撞出不一样的火花。    《google android sdk开发范例大全(第3版)》内容由android的基础知识到实际开发应用,结构清晰、语言简洁,非常适合android的初学者和android的进阶程序开发者阅读参考。 目录 《google android sdk开发范例大全(第3版)》 第1章 了解、深入、动手做 1 1.1 红透半边天的android 2 1.2 本书目的及范例涵盖范围 3 1.3 如何阅读本书 4 1.4 使用本书范例 5 1.5 参考网站 6 第2章 android初体验 7 2.1 安装android sdk与adt/ddms 8 2.2 创建第一个android项目(hello android!) 11 2.3 android应用程序架构——从此开始 15 2.4 可视化的界面开发工具 18 2.5 部署应用程序到android手机 19 第3章 用户人机界面 22 3.1 更改与显示文字标签 23 3.2 更改手机窗口画面底色 24 3.3 更改textview文字颜色 26 3.4 置换textview文字 28 3.5 取得手机屏幕大小 29 3.6 样式化的定型对象 30 .3.7 简易的按钮事件 32 3.8 手机页面的转换 34 3.9 调用另一个activity 37 3.10 不同activity之间的数据传递 41 3.11 返回数据到前一个activity 44 3.12 具有交互功能的对话框 49 3.13 置换文字颜色的机关 51 3.14 控制不同的文字字体 52 3.15 如iphone拖动相片特效 54 3.16 自制计算器 56 3.17 关于(about)程序信息 58 3.18 程序加载中,请稍候 61 3.19 全屏幕以按钮重写 63 3.20 今晚到哪儿打牙祭 64 3.21 android变脸 67 3.22 打勾显示输入的密码 69 3.23 android多语系支持 71 3.24 判断手机操作系统版本是否允许运行程序 72 3.25 两个不同的程序彼此调用 75 3.26 指定安装应用程序迁移至sd卡 78 3.27 手机动态layout主题随手势物换迁移 79 第4章 史上超豪华的手机控件 84 4.1 edittext与textview共舞 85 4.2 设计具有背景图的按钮 86 4.3 给圣诞老人的信息 88 4.4 我同意条款 90 4.5 消费券采购列表 92 4.6 向左或向右 94 4.7 专业相框设计 96 4.8 自定义下拉菜单模式 99 4.9 动态添加/删除的spinner菜单 102 4.10 心爱小宝贝相片集 104 4.11 快速地搜索手机文件引擎 107 4.12 按钮也能随单击变换 109 4.13 具自动提示功能的菜单 110 4.14 数字及模拟小时钟设计 112 4.15 动态输入日期与时间 114 4.16 猜猜红桃a在哪儿 117 4.17 后台程序运行进度提示 121 4.18 动态文字排版 124 4.19 在activity里显示列表 128 4.20 以动态列表配置选项 130 4.21 查找程序根目录下所有文件 134 4.22 加载手机磁盘里的图片文件 137 4.23 动态放大缩小imageview里的图片 139 4.24 动态旋转图片 142 4.25 猜猜我在想什么 145 4

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧