首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Server行级触发器

SQL Server行级触发器
EN

Stack Overflow用户
提问于 2010-06-24 15:05:35
回答 1查看 1.3K关注 0票数 0

我试图使用游标来实现行级delete触发器,但是当我尝试从表中删除任何行时,它似乎花费了很长时间。

我不能理解它到底停留在哪里。

代码语言:javascript
复制
/****** Object:  Trigger [delStudent]    Script Date: 06/24/2010 12:33:33 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

CREATE TRIGGER [delStudent]
   ON  [dbo].[Student]
   FOR DELETE
AS 
DECLARE @Roll as varChar(50); 
DECLARE @Name as varChar(50);
DECLARE @Age as int;
DECLARE @UserName as varChar(50);

SELECT @UserName=SYSTEM_USER;

SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
BEGIN TRANSACTION;

declare CurD cursor for select roll, Sname, age from deleted    

open CurD

WHILE @@FETCH_STATUS = 0
 BEGIN
    INSERT INTO [dbo].[Audit]
            (roll,sname,age,userId)
    VALUES
            (@Roll,@Name,@Age,@UserName)
 END    
COMMIT TRANSACTION;
Close CurD
DEALLOCATE CurD
EN

回答 1

Stack Overflow用户

发布于 2010-06-24 15:23:19

我认为你应该在插入-选择语句中转换你的光标。我不确定这是否能解决您的问题,但不管怎样,这是一个很好的最佳实践。

代码语言:javascript
复制
INSERT  [dbo].[Audit] (roll,sname,age,userId)
SELECT 'FIELDS FROM DELETED', SYSTEM_USER 
FROM deleted

尽量避免游标,这将带来更好的性能。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3107848

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档