加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

修改触发器

发布时间:2020-12-31 11:47:16 所属栏目:MySql教程 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 监测某张表修改后自动修改另一张表的数据:cf_userinfo的表结构:CREATE TABLE [dbo].[cf_userinfo] ([id] int NOT NULL IDENTITY(1,1),[uid] int NOT N

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

监测某张表修改后自动修改另一张表的数据:
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 

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!