SQL Server数据库DDL变更监控

简介: 数据库的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
以上, 通过一个触发器, 一个监控表和一个存储过程, 就可以实现记录变更记录, 提醒变更注意事项等功能.

希望以上能够帮到你.

目录
相关文章
|
7月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1116 152
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
858 156
|
6月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
585 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
5月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
326 6
|
6月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
7月前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
874 8
|
7月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
361 5
|
6月前
|
SQL 数据管理 BI
数据库操作三基石:DDL、DML、DQL 技术入门指南
本文围绕数据库操作核心语言 DDL、DML、DQL 展开入门讲解。DDL 作为 “结构建筑师”,通过CREATE(建库 / 表)、ALTER(修改表)、DROP(删除)等命令定义数据库结构;DML 作为 “数据管理员”,以INSERT(插入)、UPDATE(更新)、DELETE(删除)操作数据表记录,需搭配WHERE条件避免误操作;DQL 作为 “数据检索师”,通过SELECT结合WHERE、ORDER BY、LIMIT等子句实现数据查询与统计。三者相辅相成,是数据库操作的基础,使用时需注意 DDL 的不可撤销性、DML 的条件约束及 DQL 的效率优化,为数据库学习与实践奠定基础。
|
8月前
|
SQL 缓存 监控
SqlRest让SQL秒变Http API,还支持20+数据库(含国产数据库)
杭州奥零数据科技有限公司成立于2023年,专注于数据中台业务,维护开源项目AllData并提供商业版解决方案。AllData提供数据集成、存储、开发、治理及BI展示等一站式服务,支持AI大模型应用,助力企业高效利用数据价值。