微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

修改触发器

下面是编程之家 jb51.cc 通过网络收集整理的代码片段。

编程之家小编现在分享给大家,也给大家做个参考。

监测某张表修改自动修改另一张表的数据:
cf_userinfo的表结构:

CREATE TABLE [dbo].[cf_userinfo] (
[id] int NOT NULL IDENTITY(1,1),[uid] int NOT NULL,[name] varchar(50) COLLATE Chinese_PRC_CI_AS NULL,CONSTRAINT [PK__cf_userinfo__5535A963] PRIMARY KEY ([id])
)
ON [PRIMARY]
GO

userinfo表的结构:

CREATE TABLE [dbo].[userinfo] (
[id] int NOT NULL IDENTITY(1,CONSTRAINT [PK__userinfo__534D60F1] PRIMARY KEY ([id])
)
ON [PRIMARY]
GO

创建触发器对userinfo表的触发器

create trigger userinfoupdate
on userinfo for update  --监测userinfo表修改
as
if update(name) --如果name字段修改
begin
 print '触发userinfo表修改事件,修改cf_userinfo数据中……'; 
   declare  @id INT,@newName varchar(50),@UID INT;
   --更新前的userinfo表的ID
   select  @id = id from deleted; 
   if (exists (select * from cf_userinfo where uid [email protected]))
         begin
         --更新后的userinfo表的name字段
         select  @newName = name from inserted;
     --更新后的userinfo表的ID字段
         select  @UID = id from deleted;
         update cf_userinfo set [email protected] from userinfo where [email protected]
         end
   else
            print '无需修改cf_userinfo表'
end 

以上是编程之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐