婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MSSQL監(jiān)控數(shù)據(jù)庫的DDL操作(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等)

MSSQL監(jiān)控數(shù)據(jù)庫的DDL操作(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等)

熱門標簽:競圣地圖標注服務(wù) 智能語音車載電話機器人 云南全自動外呼系統(tǒng)公司 貴州外呼回撥系統(tǒng)是什么 智能外呼系統(tǒng)需要多少錢 陽光創(chuàng)信ai外呼獲客系統(tǒng)助力 衛(wèi)星地圖標注距離 安陽天音防封電銷卡 外呼系統(tǒng)的話術(shù)
前言: 有時候,一個數(shù)據(jù)庫有多個帳號,包括數(shù)據(jù)庫管理員,開發(fā)人員,運維支撐人員等,可能有很多帳號都有比較大的權(quán)限,例如DDL操作權(quán)限(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等),賬戶多了,管理起來就會相當麻煩,容易產(chǎn)生混亂,如果數(shù)據(jù)庫管理員不監(jiān)控數(shù)據(jù)庫架構(gòu)變更的話,就不知道誰對數(shù)據(jù)庫架構(gòu)做了啥改動(此處改動僅僅只DDL操作),尤其有時候,有些開發(fā)人員可能不按規(guī)章制度辦事,繞過或忘了通知發(fā)布人員或DBA,直接去生產(chǎn)機做一些DDL操作,那么我們就需要對數(shù)據(jù)庫架構(gòu)某些更改的事件進行監(jiān)控,如果能夠監(jiān)控并留下證據(jù),這樣既可以讓DBA或相關(guān)管理人員知曉這些變更,有效管理數(shù)據(jù)庫,也可以避免出現(xiàn)問題,出現(xiàn)扯皮現(xiàn)象,最后DBA成了背黑鍋的。

下面就是一個解決上述問題的方案,我們通過創(chuàng)建一個表DatabaseLog和DDL觸發(fā)器來解決問題,首先在msdb數(shù)據(jù)庫里面新建一個表DatabaseLog,用來保存DDL觸發(fā)器獲取的信息。其中DDL觸發(fā)器主要通過EVENTDATA()函數(shù)返回有關(guān)服務(wù)器或數(shù)據(jù)庫事件的信息。

復(fù)制代碼 代碼如下:

USE msdb;
GO
CREATE TABLE [dbo].[DatabaseLog]
(
    [DatabaseLogID]   [int]    IDENTITY(1,1) NOT NULL,
    [PostTime]        [datetime] NOT NULL,
    [DatabaseUser]    [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
    [LoginName]       [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
    [ClientHost]      [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
    [Event]           [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
    [Schema]          [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
    [Object]          [sysname] COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
    [TSQL]            [nvarchar](max) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
    [XmlEvent]        [xml] NOT NULL,
CONSTRAINT [PK_DatabaseLog_DatabaseLogID] PRIMARY KEY NONCLUSTERED
(
    [DatabaseLogID] ASC
  )WITH (PAD_INDEX= OFF, IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'Primary key for DatabaseLog records.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'DatabaseLogID'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The date and time the DDL change occurred.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'PostTime'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The user who implemented the DDL change.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'DatabaseUser'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The login which implemented the DDL change.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'LoginName'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The client machine on which implemented the DDL change.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'ClientHost'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The type of DDL statement that was executed.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'Event'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The schema to which the changed object belongs.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'Schema'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The object that was changed by the DDL statment.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'Object'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The exact Transact-SQL statement that was executed.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'TSQL'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'The raw XML data generated by database trigger.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'COLUMN',@level2name=N'XmlEvent'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'Audit table tracking all DDL changes made to the database. Data is captured by the database trigger ddlDatabaseTriggerLog.' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog'
GO
EXEC sys.sp_addextendedproperty@name=N'MS_Description', @value=N'Primary key (nonclustered) constraint' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'DatabaseLog', @level2type=N'CONSTRAINT',@level2name=N'PK_DatabaseLog_DatabaseLogID'
GO

例如,我要監(jiān)控數(shù)據(jù)庫MyAssistant的DDL操作,那么我們首先在“數(shù)據(jù)庫郵件”里面創(chuàng)建一個配置名為“ DataBase_DDL_Event”的配置文件(profile name),這個就不多講了,不知道配置的,自己先練練手把,假如我需要讓數(shù)據(jù)庫把監(jiān)控到DDL操作變動相信信息發(fā)送到我的郵箱 *****@***.com(用你自己的郵箱替代),那么只需要修改下面代碼的郵箱和profile_name即可。

復(fù)制代碼 代碼如下:

USE MyAssistant;
GO

CREATE TRIGGER [DTG_DatabaseDdlTriggerLog]
ON DATABASE
FOR DDL_DATABASE_LEVEL_EVENTS
AS
BEGIN
    SET NOCOUNT ON;

    DECLARE @data XML;
    DECLARE @schema sysname;
    DECLARE @object sysname;
    DECLARE @eventType sysname;
    DECLARE @tableHTML  NVARCHAR(MAX) ;

    SET @data = EVENTDATA();
    SET @eventType = @data.value('(/EVENT_INSTANCE/EventType)[1]', 'sysname');
    SET @schema = @data.value('(/EVENT_INSTANCE/SchemaName)[1]', 'sysname');
    SET @object = @data.value('(/EVENT_INSTANCE/ObjectName)[1]', 'sysname')

    IF @object IS NOT NULL
        PRINT '  ' + @eventType + ' - ' + @schema + '.' + @object;
    ELSE
        PRINT '  ' + @eventType + ' - ' + @schema;

    IF @eventType IS NULL
        PRINT CONVERT(nvarchar(max), @data);

    INSERT [msdb].[dbo].[DatabaseLog]
        (
        [PostTime],
        [DatabaseUser],
        [LoginName],
        [ClientHost],
        [Event],
        [Schema],
        [Object],
        [TSQL],
        [XmlEvent]
        )
    VALUES
        (
        GETDATE(),
        CONVERT(sysname, CURRENT_USER),
        @data.value('(/EVENT_INSTANCE/LoginName)[1]', 'nvarchar(max)'),
        CONVERT(sysname, HOST_NAME()),
        @eventType,
        CONVERT(sysname, @schema),
        CONVERT(sysname, @object),
        @data.value('(/EVENT_INSTANCE/TSQLCommand)[1]', 'nvarchar(max)'),
        @data
        );

    SET @tableHTML =  
    N'H1>DDL Event/H1>' +    
    N'table border="0">' +    
    N'tr>th>Post Time/th>th>User/th>th>Login/th>th>ClientHost/th>' +    
    N'th>TSQL/th>th>/tr>' +    
    CAST(( SELECT
    td = PostTime,       '',                    
    td = DatabaseUser, '',       
    td = LoginName, '',    
    td = ClientHost, '',        
    td = TSQL, ''              
    FROM msdb.dbo.DatabaseLog              
    WHERE DatabaseLogID =(select max(DatabaseLogID) from msdb.dbo.DatabaseLog)              
    FOR XML PATH('tr'), TYPE     ) AS NVARCHAR(MAX) ) +     N'/table>' ;

    EXEC msdb.dbo.sp_send_dbmail    
             @profile_name = 'DataBase_DDL_Event',
        @recipients='***@***.com',    
        @subject = 'DDL Event - DataBase MyAssistant',    
        @body = @tableHTML,  
        @body_format = 'HTML' ;
END;
GO

接下來我們來測試一下,假如一個用戶Test登錄數(shù)據(jù)庫,一不小心刪除了一個Test的表,如下圖一所示,那么我將收到一封郵件,提示我用戶Test在那臺客戶端主機執(zhí)行了啥DDL操作(如下圖二所示),當然郵件的樣式、排版有興趣的可以去美化一下。

 

您可能感興趣的文章:
  • mysql數(shù)據(jù)庫基本語法及操作大全
  • 數(shù)據(jù)庫語言分類DDL、DCL、DML詳解
  • MySQL ddl語句的使用
  • Mysql DDL常見操作匯總
  • Mysql學(xué)習(xí)之創(chuàng)建和操作數(shù)據(jù)庫及表DDL大全小白篇

標簽:鄂爾多斯 周口 預(yù)約服務(wù) 營口 寧夏 欽州 湘潭 河源

巨人網(wǎng)絡(luò)通訊聲明:本文標題《MSSQL監(jiān)控數(shù)據(jù)庫的DDL操作(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等)》,本文關(guān)鍵詞  MSSQL,監(jiān)控,數(shù)據(jù)庫,的,DDL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MSSQL監(jiān)控數(shù)據(jù)庫的DDL操作(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等)》相關(guān)的同類信息!
  • 本頁收集關(guān)于MSSQL監(jiān)控數(shù)據(jù)庫的DDL操作(創(chuàng)建,修改,刪除存儲過程,創(chuàng)建,修改,刪除表等)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线综合视频播放| av一区二区三区黑人| 国产白丝网站精品污在线入口| 欧美高清视频不卡网| 亚洲永久精品大片| 欧美日韩情趣电影| 亚洲午夜三级在线| 91精品国产美女浴室洗澡无遮挡| 日本少妇一区二区| 久久综合久久综合亚洲| 成人精品视频.| 一区二区国产视频| 欧美一区二区在线免费观看| 精品一区二区三区久久久| 国产欧美精品国产国产专区| 91一区二区在线观看| 午夜久久久影院| 国产亚洲综合av| 欧美午夜理伦三级在线观看| 久久国产福利国产秒拍| 日韩一区欧美小说| 91精品国产91久久久久久最新毛片| 日韩黄色免费电影| 欧美精品一区二区三区蜜桃 | 亚洲精品久久久蜜桃| 欧美美女黄视频| 国产成人在线观看免费网站| 亚洲在线观看免费| 国产亚洲综合性久久久影院| 欧美丝袜自拍制服另类| 国产成人精品午夜视频免费| 午夜精品免费在线| 亚洲视频免费观看| 久久免费看少妇高潮| 欧美撒尿777hd撒尿| 国产成人精品影院| 美女国产一区二区三区| 一区二区三区国产| 中文字幕+乱码+中文字幕一区| 欧美一卡二卡在线观看| av福利精品导航| 国产一区二区三区在线观看免费视频 | 在线亚洲免费视频| 国产成人精品免费视频网站| 午夜不卡av在线| 亚洲视频资源在线| 国产精品乱子久久久久| 久久精品亚洲国产奇米99| 欧美一区午夜视频在线观看| 欧洲一区二区三区在线| 91在线你懂得| 不卡在线观看av| 国产成人av一区二区三区在线观看| 蜜臀va亚洲va欧美va天堂| 午夜欧美一区二区三区在线播放| 一区二区三区中文在线观看| 亚洲三级免费观看| 日韩美女久久久| 中文字幕在线播放不卡一区| 国产欧美日韩亚州综合| 欧美国产在线观看| 国产精品你懂的在线欣赏| 欧美国产精品劲爆| 综合网在线视频| 亚洲黄色免费电影| 亚洲大片精品永久免费| 日韩av在线播放中文字幕| 蜜臀va亚洲va欧美va天堂| 国内外成人在线| 成a人片国产精品| 欧美亚洲国产一卡| 日韩亚洲欧美在线观看| 精品黑人一区二区三区久久 | 美女mm1313爽爽久久久蜜臀| 日本一不卡视频| 黑人精品欧美一区二区蜜桃| 国产精品1024| 91色视频在线| 91精品国产91综合久久蜜臀| 精品99一区二区三区| 中文字幕精品一区二区三区精品| 1000部国产精品成人观看| 亚洲五码中文字幕| 国产综合一区二区| 91老师国产黑色丝袜在线| 欧美另类久久久品| 精品福利一区二区三区免费视频| 中文一区在线播放| 亚洲va欧美va人人爽| 极品销魂美女一区二区三区| 成人精品国产免费网站| 欧美丰满少妇xxxxx高潮对白| 欧美一区二区国产| 1024国产精品| 韩日av一区二区| 欧美丝袜丝交足nylons| 中文字幕免费一区| 日韩电影免费在线看| 97se狠狠狠综合亚洲狠狠| 日韩午夜激情电影| 一卡二卡欧美日韩| 国产一区二区看久久| 欧美精品一级二级三级| 亚洲欧洲在线观看av| 久久不见久久见中文字幕免费| av日韩在线网站| 精品人在线二区三区| 亚洲成人福利片| 99久久精品情趣| 精品国产第一区二区三区观看体验| 一区在线中文字幕| 国内精品免费在线观看| 欧美精选午夜久久久乱码6080| 国产三级精品在线| 精品影院一区二区久久久| 欧美视频一区二区三区| 亚洲欧美一区二区三区久本道91| 国产精品亚洲午夜一区二区三区| 欧美日韩精品免费观看视频| 中文字幕人成不卡一区| 成人av中文字幕| 欧美国产成人在线| 国产成人无遮挡在线视频| 精品国产一二三| 久久国产乱子精品免费女| 91精品国产美女浴室洗澡无遮挡| 亚洲精品v日韩精品| 91免费国产在线| 亚洲精品久久7777| 色婷婷久久综合| 亚洲精品第一国产综合野| 色综合色综合色综合色综合色综合 | 亚洲欧洲精品天堂一级| 国产成人在线网站| 久久久综合九色合综国产精品| 久久9热精品视频| 亚洲精品一区二区三区蜜桃下载 | 欧美激情综合在线| 国内精品国产成人| 国产亚洲一区字幕| 粉嫩aⅴ一区二区三区四区 | 国产偷国产偷亚洲高清人白洁 | 色哟哟一区二区| 一级女性全黄久久生活片免费| 在线中文字幕一区二区| 午夜精品福利一区二区三区av| 欧美高清性hdvideosex| 久久精品国产精品亚洲综合| 欧美精品一区二区三区视频| 国产91精品入口| 日韩一区在线播放| 欧美女孩性生活视频| 精品一区二区综合| 国产精品国产三级国产a| av激情综合网| 日一区二区三区| 久久亚洲捆绑美女| 91丨九色丨蝌蚪丨老版| 日韩国产欧美在线播放| 久久久久久久精| 欧美性视频一区二区三区| 美女一区二区视频| 国产精品网站在线观看| 欧洲一区二区三区在线| 精品亚洲aⅴ乱码一区二区三区| 久久女同精品一区二区| 97se亚洲国产综合自在线观| 日本va欧美va欧美va精品| 国产精品乱人伦一区二区| 在线不卡免费av| a4yy欧美一区二区三区| 丝袜美腿亚洲色图| 中文字幕av不卡| 日韩一区二区三区在线视频| 成人h版在线观看| 精品在线观看免费| 五月天中文字幕一区二区| 日本一区二区免费在线观看视频| 在线免费不卡视频| 久久99国产精品免费网站| 亚洲午夜久久久久久久久久久| 2024国产精品| 欧美日韩黄色影视| 岛国av在线一区| 久久99深爱久久99精品| 亚洲电影一区二区三区| 中文字幕巨乱亚洲| 久久综合久久综合亚洲| 欧美浪妇xxxx高跟鞋交| 9人人澡人人爽人人精品| 极品少妇xxxx偷拍精品少妇| 亚洲第一久久影院| 一级特黄大欧美久久久| 日韩美女啊v在线免费观看| 国产视频在线观看一区二区三区| 5月丁香婷婷综合| 在线观看日韩毛片| 色88888久久久久久影院野外| 成人看片黄a免费看在线| 国产一区二区三区四区五区入口|