zoukankan      html  css  js  c++  java
  • SQL Server触发器Trigger(1)

    为了演示触发器,下面例子分别实现插入,删除触发器。

    示例之前,先创建两个表,关关联起来。

    代码
    --创建一个表[Topic]
    CREATE TABLE dbo.Topic
    (
        TopicId 
    INT IDENTITY(1,1PRIMARY KEY NOT NULL,
        Title 
    NVARCHAR(300NOT NULL,
        Content 
    NVARCHAR(2000NOT NULL,
        Author 
    NVARCHAR(50NOT NULL,
        Reply 
    INT DEFAULT(0NOT NULL    
    )
    GO

    另外一个表,

    代码
    --创建另外一个表[SubTopic],其中有一字段是表[Topic]的主键,即是Foreign key
    CREATE TABLE dbo.SubTopic
    (
        SubTopicId 
    INT IDENTITY(1,1PRIMARY KEY NOT NULL,
        TopicId 
    INT,--外键 reference table dbo.Topic primary key
        Author NVARCHAR(50NOT NULL,
        Content 
    NVARCHAR(4000NOT NULL    
    )
    GO

    接下来,就是触发器实现代码,当有论题被回复时,在主表中的Reply字段加1。

    代码
    --为表[SubTopic]创建一个插入的触发器
    CREATE TRIGGER dbo.tri_SubTopic_Insert ON dbo.SubTopic
    FOR INSERT
    AS
    BEGIN
        
    SET NOCOUNT ON
        
    DECLARE @key INT
        
    SELECT @key = [TopicId] FROM inserted
        
    --当有记录插入时,同时更新表[Topic]的[reply]字段,回复数量添加1.
        UPDATE [dbo].[Topic] SET [Reply] = [Reply] + 1 WHERE [TopicId] = @key    
    END

    GO

    当有论题被删除时,在主表中的Reply字段也相应减1。

    代码
    --为表[SubTopic]创建一个删除触发器
    CREATE TRIGGER dbo.tri_SubTopic_Delete ON dbo.SubTopic
    FOR DELETE
    AS
    BEGIN
        
    SET NOCOUNT ON
        
    DECLARE @key INT    
        
    SELECT @key = [TopicId] FROM deleted
        
    --在有记录删除时,同时更新表[Topic]的[reply]字段,回复数量减1.
        UPDATE [dbo].[Topic] SET [Reply] = [Reply] - 1 WHERE [TopicId] = @key    
    END

    GO

    最后一个触发器,就是主表的论题被删除时,所有子表相应本论题的回复应也全部删除,

    代码
    CREATE TRIGGER dbo.tri_Topic_Delete ON dbo.Topic
    FOR DELETE
    AS
    BEGIN
        
    SET NOCOUNT ON    
        
    DECLARE @key INT    
        
    SELECT @key = [TopicId] FROM deleted
        
    DELETE FROM [dbo].[SubTopic] WHERE [TopicId] = @key
    END
  • 相关阅读:
    node拦截器设置
    node中session存储与销毁,及session的生命周期
    node做验证码
    防止iframe被别的网站引用
    表单元素disabled禁用后不能自动提交到服务器
    bootstrap 模态框中弹出层 input不能获得焦点且不可编辑
    post请求和get请求content_type的种类
    Firefly在线一键安装
    Firefly通讯协议-
    Firefly《暗黑世界》碎片合成部分代码
  • 原文地址:https://www.cnblogs.com/insus/p/1918840.html
Copyright © 2011-2022 走看看