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
  • 相关阅读:
    moya
    语言是人脑中影像的表述工具
    Ad-hoc--拉丁文--for this purpose only
    语言是人类对自我意识的表述工具:对世界和事物多深刻的认识,就会有多丰富和符合 逻辑的语言表述
    知行合一:知其然知其所以然
    语言是世界观、方法论的重组和表述
    任何能用编程语言描述的东西都能够用人类语言描述
    面向对象的几个视角
    待解决问题 jscore 与 node.js jsbridge
    浅谈CSRF攻击方式
  • 原文地址:https://www.cnblogs.com/insus/p/1918840.html
Copyright © 2011-2022 走看看