导航
  • 主页
  • 基础类
  • 应用实例
  • 新技术前沿

紧急(触发器问题)

yangq4000 2003-12-11 05:18:00
表t1 bh char, a,b float
bh a b
1001 1 1
1002 2 2
1001 2 2
1002 3 3
表t2
bh m [5%] [10%]
1001 a 0.15 0.3
1001 b 0.15 0.3
1002 a 0.25 0.5
1002 b 0.25 0.5
其中:
1001 m [5%]
0.15=sum(t1.a) where bh=1001
就是说,我想改变t1表中编号是1001的数据a,b的值,触发t2表中编号也是1001的数据的值,假如编号有很多的话,怎么写呢?谢谢
我想改变t1中的数值,达到t2那种效果,如何用触发器实现?谢谢
...全文
4 点赞 收藏 4
写回复
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
victorycyz 2003-12-12
记得你不久前已经发过一个相同问题的贴,只不过百分比是10%、20%、30%而已。不知道你对那贴中的别人的回复理解得怎样?我觉得如果有什么新的疑问,最好是根据回贴的内容展开讨论。别人才知道你的理解消化做到什么程度了。重复发贴,实在没什么意思。

再说一下我的意见,t2表是多余的,不需要。更不需要什么触发器来处理了。
回复
DigJim 2003-12-11
上面的写错了!!

CREATE TRIGGER test ON t1
FOR update
AS
declare @sumA decimal(18,2)
declare @sumB decimal(18,2)

select @sumA=sum(t1.a),@sumB=sum(t1.b) from t1
where t1.bh=(select bh from inserted)

update t2 set [5%] =(sumA*0.05),[10%]=(sumA*0.25)
where t2.bh=(select bh from inserted) AND m='a'

update t2 set [5%] =(sumB*0.05),[10%]=(sumB*0.25)
where t2.bh=(select bh from inserted) AND m='b'
go
回复
DigJim 2003-12-11
CREATE TRIGGER test ON t1
FOR update
AS
declare @sumA decimal(18,2)
declare @sumB decimal(18,2)

select @sumA=sum(t1.a),@sumB=sum(t1.b) from t1
where t1.bh=(select bh from inserted)

update t2 set [5%] =(sumA*0.05),[10%]=(sumB*0.25)
where t2.bh=(select bh from inserted)
go

回复
shuiniu 2003-12-11
不需要表t2,用视图就可以了!
create table t1(bh char(4), a float,b float)
insert t1 values('1001',1,1)
insert t1 values('1002',2,2)
insert t1 values('1001',2,2)
insert t1 values('1002',3,3)

create view test
as
select bh,'a' m,sum(a) * 0.05 [5%],sum(b)*0.1 as [10%]
from t1
group by bh
union all
select bh,'b', sum(a) * 0.05 [5%],sum(b)*0.1 [10%]
from t1
group by bh
go

select * from test order by bh
回复
发动态
发帖子
MS-SQL Server
创建于2007-09-28

3.2w+

社区成员

MS-SQL Server相关内容讨论专区
申请成为版主
社区公告
暂无公告