一个关于“触发器”的实例问题,给100分!!急啊

crazybmm 2004-11-11 04:10:16
现在想写一个触发器,大致要实现的就是在一张工资表里如果某个人的工资变动的话(时间和金额),那么要把这个人的变动前和变动后的记录重新插入到一张新表(alteror)
工资表名wage 里有编号(ID) 工资变动时间(CHNG_DATE)和工资变动金额(CHNG_WAGE)
请问如何编写。另外,这个语句是不是写在SQL SERVER 里的存储过程里?
...全文
130 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
mazekui 2004-11-11
  • 打赏
  • 举报
回复
而在Oracel9i里就有更新前和更新后两个事件了!
mazekui 2004-11-11
  • 打赏
  • 举报
回复
用触发器也是一种好的习惯,不错,不过在Sql2000中触发器只有update事件就是说在你更改后才触发的那么在这个触发器里面只能记录到你更改后的记录而记录不了你更改前的记录。
所以,你最好在更改前把记录给记录下来了!
而记录更改后的记录的触发器写法如下 :
create trigger triggername on wage
for update
as
if update(CHNG_WAGE)
begin
insert into alteror select * from deleted --注意这种写法需要历史表和操作表的结构是完全一样的
end
okwinds 2004-11-11
  • 打赏
  • 举报
回复
楼上说的对,但是补充说明一点,不是不触发,是触发了但是因为异常,而使得操作不继续无法插入,产生了回滚。如果你的应用是在大型系统上的,那么还是建议你用stored procedure,但是小型系统就无所谓了。

如果要用stored procedure,又要实现自动化,就需要用到service agant,然后建立一个job,之后设定一个操作的间隔时间就可
suntonycomm 2004-11-11
  • 打赏
  • 举报
回复
我认为这种情况不要用触发器,
1、触发器本身来说没有存储过程稳定,不触发的偶然情况也是有的。

2、由于一个人工资情况变动的条件不会太简单,用触发器来判断的话不合适。


----------------------------------
应该用存储过程,在某种条件下执行一下就可以了。


okwinds 2004-11-11
  • 打赏
  • 举报
回复
create trigger triggername on wage
for update
as
if update(CHNG_WAGE)
begin
insert into alteror select * from deleted --注意这种写法需要历史表和操作表的结构是完全一样的
end

62,266

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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