下載吧 - 綠色安全的游戲和軟件下載中心

          軟件下載吧

          當前位置:軟件下載吧 > 數據庫 > MS_SQL > SQL開發知識:SQL Server 添加Delete操作回滾日志方式

          SQL開發知識:SQL Server 添加Delete操作回滾日志方式

          時間:2024-02-05 12:47作者:下載吧人氣:13

          我們在操作表的時候難免會遇到誤刪除,或者刪掉的數據還想恢復的情況。

          也許細心的朋友會用begin tran rollback/commit 這種事務來避免出現失誤,但這并不是最保險的。

          如果提交了事物發現刪錯了或者忘記提交從而導致表被鎖,這些問題總是不可避免的。

          廢話不多說了,下面直接進入正題,通過觸發器記錄刪除日志,避免誤刪除帶來的尷尬。

          下面這段sql粘過去直接運行,建立一個存儲過程:

          CREATE PROCEDURE [dbo].[SP_DELETE_LOG]
          @TABLENAME VARCHAR(50)
          AS
          BEGIN
          SET NOCOUNT ON;
          IF NOT EXISTS(SELECT * FROM sys.tables WHERE NAME = @TABLENAME AND TYPE = ‘U’ )
          BEGIN
          PRINT’ERROR:not exist table ‘+@TABLENAME
          RETURN
          END
          IF (@TABLENAME LIKE’BACKUP_%’ OR @TABLENAME=’UPDATE_LOG’ )
          BEGIN
          –PRINT’ERROR:not exist table ‘+@TABLENAME
          RETURN
          END
          –================================判斷是否存在 UPDATE_LOG 表============================
          IF NOT EXISTS(SELECT * FROM sys.tables WHERE NAME = ‘UPDATE_LOG’ AND TYPE = ‘U’)
          CREATE TABLE UPDATE_LOG
          (
          UpdateGUID VARCHAR(36),
          UpdateTime DATETIME,
          TableName varchar(20),
          UpdateType varchar(6),
          RollBackSQL varchar(1000)
          )
          –=================================判斷是否存在 BACKUP_ 表================================
          IF NOT EXISTS(SELECT * FROM sys.tables WHERE NAME = ‘BACKUP_’+@TABLENAME AND TYPE = ‘U’)
          BEGIN
          –DECLARE @SQL VARCHAR(500)
          –SET @SQL=’SELECT TOP 1 NEWID() AS [UpdateGUID],* INTO BACKUP_’+@TABLENAME+’ FROM ‘+ @TABLENAME+’
          — DELETE FROM BACKUP_’+@TABLENAME
          –SELECT @SQL
          –EXEC(@SQL)
          DECLARE test_Cursor CURSOR FOR
          SELECT COLUMN_NAME,DATA_TYPE,CHARACTER_MAXIMUM_LENGTH FROM INFORMATION_SCHEMA.columns
          WHERE TABLE_NAME=@TABLENAME
          OPEN test_Cursor
          DECLARE @SQLTB NVARCHAR(MAX)=”
          DECLARE @COLUMN_NAME NVARCHAR(50),@DATA_TYPE VARCHAR(20),@CHARACTER_MAXIMUM_LENGTH INT
          FETCH NEXT FROM test_Cursor INTO @COLUMN_NAME,@DATA_TYPE,@CHARACTER_MAXIMUM_LENGTH
          WHILE @@FETCH_STATUS=0
          BEGIN
          SET @SQLTB=@SQLTB+'[‘+@COLUMN_NAME+’] ‘+@DATA_TYPE+CASE ISNULL(@CHARACTER_MAXIMUM_LENGTH,0) WHEN 0 THEN ” WHEN -1 THEN ‘(MAX)’ ELSE'(‘+CAST(@CHARACTER_MAXIMUM_LENGTH AS VARCHAR(10))+’)’ END+’,’
          FETCH NEXT FROM test_Cursor INTO @COLUMN_NAME,@DATA_TYPE,@CHARACTER_MAXIMUM_LENGTH
          END
          SET @SQLTB=’CREATE TABLE BACKUP_’+@TABLENAME+’ (UpdateGUID varchar(36),’+SUBSTRING(@SQLTB,1,LEN(@SQLTB)-1)+’)’
          EXEC (@SQLTB)
          CLOSE test_Cursor
          DEALLOCATE test_Cursor
          END
          –======================================判斷是否存在 DELETE 觸發器=========================
          IF NOT EXISTS(SELECT * FROM sys.objects WHERE NAME = ‘tg_’+@TABLENAME+’_Delete’ AND TYPE = ‘TR’)
          BEGIN
          DECLARE @SQLTR NVARCHAR(MAX)
          SET @SQLTR=’
          CREATE TRIGGER tg_’+@TABLENAME+’_Delete
          ON ‘+@TABLENAME+’
          AFTER delete
          AS
          BEGIN
          SET NOCOUNT ON;
          –==============================獲取GUID==========================================
          DECLARE @NEWID VARCHAR(36)=NEWID()
          –==============================將刪掉的數據插入備份表============================
          INSERT INTO [dbo].[BACKUP_’+@TABLENAME+’]
          SELECT @NEWID,* FROM deleted
          –==============================記錄日志和回滾操作的SQL===========================
          –*********************生成列名**********************
          DECLARE @COLUMN NVARCHAR(MAX)=””
          SELECT @COLUMN+=”,[”+COLUMN_NAME+”]” FROM INFORMATION_SCHEMA.columns
          WHERE TABLE_NAME=”’+@TABLENAME+”’
          AND COLUMNPROPERTY(OBJECT_ID(”’+@TABLENAME+”’),COLUMN_NAME,”IsIdentity”)<>1 –非自增字段
          SET @COLUMN=SUBSTRING(@COLUMN,2,LEN(@COLUMN))
          INSERT INTO [dbo].[UPDATE_LOG]
          SELECT @NEWID,GETDATE(),”’+@TABLENAME+”’,”DELETE”,”INSERT INTO ‘+@TABLENAME+’ SELECT ”+@COLUMN+” FROM BACKUP_’+@TABLENAME+’ WHERE UPDATEGUID=”””+@NEWID+””””
          END

          EXEC(@SQLTR)
          END
          END

          標簽MSSQL,SQLServer,技術文檔,數據庫,SQLSERVER

          相關下載

          查看所有評論+

          網友評論

          網友
          您的評論需要經過審核才能顯示

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 久久se精品一区二区国产| 无码人妻精品一区二区蜜桃百度| 国产a∨精品一区二区三区不卡| 国产短视频精品一区二区三区| 久久精品综合一区二区三区| 无码人妻啪啪一区二区| 国产爆乳无码一区二区麻豆 | 国产suv精品一区二区6| 精品爆乳一区二区三区无码av| 亚洲av鲁丝一区二区三区| 精品亚洲AV无码一区二区三区 | 亚洲国产日韩一区高清在线 | 亚洲AV美女一区二区三区| 日本免费一区二区三区四区五六区| 亚洲av不卡一区二区三区| 日本免费一区二区三区| 欧亚精品一区三区免费| 一区二区三区在线播放| 日韩视频一区二区三区| 97se色综合一区二区二区| 国产精品亚洲一区二区无码 | 一区二区高清在线| 无码人妻精品一区二区| 狠狠综合久久av一区二区| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 国产熟女一区二区三区四区五区 | 日韩一区二区在线视频| 国产精品综合一区二区三区| 精品一区二区三区中文字幕| 国产一区二区三区在线电影 | 国产午夜福利精品一区二区三区 | 波多野结衣免费一区视频| 国产伦一区二区三区高清| 久久精品国产第一区二区| 亚洲av无码一区二区三区网站| 国产在线无码视频一区二区三区| 丰满人妻一区二区三区视频53| 日本在线观看一区二区三区| 国产成人一区在线不卡| 国产成人无码AV一区二区| 精品少妇一区二区三区视频 |