SQL Server数据库DDL变更监控

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 数据库的DDL语言, 就是关系型数据库的三大类语言中的一种, 数据定义语言(Data Definition Language), 主要是数据结构和数据库对象的定义. 有CREATE , ALTER, DROP 等语句组成.工作中经常需要对数据对象变更进行监控, 可能存在以下的场景:监控所有的变更, 并保留变更记录.比如对某些表结构的变更可能需要对其他的数据库的的表进行同步变更.可能某些View的改变需要同步修改默写Stored Procedure 存储过程.某些变更需要同步修改相应的应用程序.经过研究, 可以通过全局触发器和自定义的监控Stored Procedure来实现.

数据库的DDL语言, 就是关系型数据库的三大类语言中的一种, 数据定义语言(Data Definition Language), 主要是数据结构和数据库对象的定义. 有CREATE , ALTER, DROP 等语句组成.

工作中经常需要对数据对象变更进行监控, 可能存在以下的场景:

监控所有的变更, 并保留变更记录.
比如对某些表结构的变更可能需要对其他的数据库的的表进行同步变更.
可能某些View的改变需要同步修改默写Stored Procedure 存储过程.
某些变更需要同步修改相应的应用程序.
经过研究, 可以通过全局触发器和自定义的监控Stored Procedure来实现.

首先建立一个触发器Trigger
触发器是一种特殊类型的存储过程,在数据库服务器中发生事件时自动运行。在DML语言, 即我们常用的INSERT, UPDATE 和 DELETE 操作, 可以触发特点的程序, 检查数据完整性, 同步更新等操作.

这次我们用DDL的Tigger, 建立一个全局的Server.

--============ Create Trigger ============
CREATE TRIGGER TRG_DDL_CHANGES ON ALL SERVER

FOR 
CREATE_TABLE, ALTER_TABLE, DROP_TABLE, 
CREATE_VIEW, DROP_VIEW, ALTER_VIEW

AS
BEGIN
...
END;
GO
记得需要排除对tempdb的监控, 程序处理的临时表都是创建到tempdb中的, 没有必要监控这种临时的对象.

--============ Don't log tempdb DDL ============
SET @_databaseName = EVENTDATA().value('(/EVENT_INSTANCE/DatabaseName)[1]', 'nvarchar(max)')
IF @_databaseName IN ('tempdb') RETURN

新建一个表来记录变更的记录.

CREATE TABLE dbo.DBA_DDL_CHANGE_LOG
(

LOG_ID INT IDENTITY PRIMARY KEY,
EVENT_DATA XML NOT NULL,
WARNING_TYPE VARCHAR(20) NULL,
WARNING_COMMENT NVARCHAR(200) NULL,
HANDLE_COMMENT  NVARCHAR(200) NULL,
HANDLE_BY VARCHAR(20) NULL

);
GO
记录变更的记录, 并把logId传入到自定义的存储过程中, 在这个SP中, 我们可以对我们关心的QQ账号拍卖平台对象进行不同时间的告警和相应处置.

INSERT  INTO dbo.DBA_DDL_CHANGE_LOG (event_data)
VALUES  (EVENTDATA());

SET @logId = @@IDENTITY
EXEC dbo.SP_DBA_MONITOR_DDL_CHANGE @logId

建立自定义的存储过程Stored Procedure
我建立了一张表, 用来定义一些存储监控对象的表, 如果对象在我的监控清单中, 就Raise Error, 并把事先定义好的消息提示给变更表结构的DBA, 如有必要, 可以回滚当前的变更操作.

SELECT

    @_eventType = event_data.value('(/EVENT_INSTANCE/EventType)[1]', 'nvarchar(max)'),
    @_databaseName = event_data.value('(/EVENT_INSTANCE/DatabaseName)[1]', 'nvarchar(max)'),
    @_objectName = event_data.value('(/EVENT_INSTANCE/ObjectName)[1]', 'nvarchar(max)'),
    @_objectType = event_data.value('(/EVENT_INSTANCE/ObjectType)[1]', 'nvarchar(max)')

FROM PerfAnaly.dbo.DBA_DDL_CHANGE_LOG
WHERE log_id = @logId

SELECT @_warnignComment = COMMENT,

    @_warningPurpose = MONITOR_PURPOSE

FROM dbo.DBA_DDL_MONITOR WITH (NOLOCK)
WHERE DATABASE_NAME = @_databaseName

    AND OBJECT_NAME = @_objectName
    AND OBJECT_TYPE = @_objectType

--============ Check table is in Archive or not ============
IF @_eventType IN ('ALTER_TABLE', 'DROP_TABLE', 'DROP_VIEW', 'ALTER_VIEW') AND @_warnignComment IS NOT NULL
BEGIN

UPDATE  dbo.DBA_DDL_CHANGE_LOG
SET     WARNING_TYPE = @_warningPurpose, 
        WARNING_COMMENT = @_warnignComment
WHERE   LOG_ID = @logId

RAISERROR('### %s ###: %s !!!', 11, 1, @_warningPurpose, @_warnignComment)

END
以上, 通过一个触发器, 一个监控表和一个存储过程, 就可以实现记录变更记录, 提醒变更注意事项等功能.

希望以上能够帮到你.

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
28天前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
132 3
|
4天前
|
消息中间件 资源调度 关系型数据库
如何在Flink on YARN环境中配置Debezium CDC 3.0,以实现实时捕获数据库变更事件并将其传输到Flink进行处理
本文介绍了如何在Flink on YARN环境中配置Debezium CDC 3.0,以实现实时捕获数据库变更事件并将其传输到Flink进行处理。主要内容包括安装Debezium、配置Kafka Connect、创建Flink任务以及启动任务的具体步骤,为构建实时数据管道提供了详细指导。
21 9
|
11天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
12 2
|
14天前
|
存储 数据挖掘 数据库
数据库数据恢复—SQLserver数据库ndf文件大小变为0KB的数据恢复案例
一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库不可用。管理员试图恢复数据库,发现有数个ndf文件大小变为0KB。 虽然NDF文件大小变为0KB,但是NDF文件在磁盘上还可能存在。可以尝试通过扫描&拼接数据库碎片来恢复NDF文件,然后修复数据库。
|
30天前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
50 11
|
29天前
|
SQL 监控 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
29天前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
1月前
|
SQL 存储 数据可视化
SQL 数据库大揭秘:连接数字世界的魔法桥梁
在数字化时代,数据如繁星般璀璨,而 SQL 数据库则像强大的引力场,有序汇聚、整理和分析这些数据。SQL 数据库是一个巨大的数字宝库,装满各行各业的“宝藏”。本文将带你探索 SQL 数据库在电商、金融、医疗和教育等领域的应用。例如,在电商中,它能精准推荐商品;在金融中,它是安全卫士,防范欺诈;在医疗中,它是健康管家,管理病历;在教育中,则是智慧导师,个性化教学。此外,还将介绍如何利用板栗看板等工具实现数据可视化,提升决策效率。
|
1月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
46 3
|
1月前
|
SQL 数据管理 数据库
文章初学者指南:SQL新建数据库详细步骤与最佳实践
引言:在当今数字化的世界,数据库管理已经成为信息技术领域中不可或缺的一部分。作为广泛使用的数据库管理系统,SQL已经成为数据管理和信息检索的标准语言。本文将详细介绍如何使用SQL新建数据库,包括准备工作、具体步骤和最佳实践,帮助初学者快速上手。一、准备工作在开始新建数据库之前,你需要做好以下准备工作
109 3
下一篇
无影云桌面