sql server触发器和存储过程

有时候在更新在增加字段是,需要给另外一张表根据一些条件更新,这个时候调用存储过程就美滋滋了,下面是sql server存储过程

use Manager
declare my_cursor cursor scroll dynamic --scroll表示可以向前或向后移动   dynamic:表示可写也可读,
for
select user_id,address from dbo.teacher --定义my_cursor 游标

open my_cursor --打开游标
declare @address nvarchar(128) --定义一个变量
declare @id nvarchar(128) --定义一个变量
fetch next from my_cursor into @id,@address --游标停在第一条记录前面,第一次执行,测试有没有记录存在
while @@fetch_status=0 --取数据,直到-2即没有记录
begin
		PRINT  @id+'  '+@address  --fetch next from my_cursor
		update dbo.electric set address=@address where user_id=@id;--更新另外一个表中的数据
		update dbo.water set address=@address where user_id=@id;--更新另外一个表中的数据
		FETCH NEXT FROM  my_cursor  INTO  @id,@address
end

--fetch first from my_cursor into @name
--print @name
 --update temp set F9='zzg' where current of my_cursor 
/* delete from 个人资料 where current of my_cursor */
--commit;--提交事务
    close my_cursor--关闭游标
    deallocate my_cursor--释放资源

触发器
在更新数据的时候,一个表中的数据改变了,需要更新其他表中的数据,这时候价格触发器,那就不要需要写更多数据了
删除触发器
BEGIN
if update(user_id) --删除或者更新触发
declare @id VARCHAR(50);–固定翼变量
select @id=user_id from deteled;–deteled表示当前删除的数据行
DELETE dbo.electric where user_id=@id;–更新另外一个表中的数据
DELETE dbo.water where user_id=@id;–更新另外一个表中的数据
END
更新触发器(这个例子就是更改teacher表中的地址,然后触发,更新其他表的地址)
BEGIN
if update(address)
declare @id VARCHAR(50);
declare @address VARCHAR(50);
select @id=user_id from inserted;–inserted表示当前修改的数据行
select @address=address from inserted;–inserted表示当前修改的数据行
update dbo.electric set address=@address where user_id=@id;–更新另外一个表中的数据
update dbo.water set address=@address where user_id=@id;–更新另外一个表中的数据
END

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值