SQL 自动记录存储过程,表,函数的创建修改和删除 -相当于SVN一样
在项目开发过程中,项目管理者通常都很希望对项目的开发进展有一个日志的记录。代码的记录和管理可以通过TFS或者VSS等工具去管理。但是数据库却没有记录开发日志这一功能。这在实际开发中很不方便,特别是大量的存储过程改动。
那么针对这一个需求,在数据库中建立一个数据库的触发器,记录存储过程的代码修改!
--第一步:建库建表
if exists(select 1 from master.dbo.sysdatabases where name='AuditDB')
drop database AuditDB
go
create database AuditDB
go
use AuditDB
go
if object_id('DDLEvents','u')is not null
drop table DDLEvents
go
create table DDLEvents(
EventDate datetime default (getdate()) NOT null, --事件时间
EventType nvarchar(64) null, --事件类型
EventDDL nvarchar(max) null, --事件内容
EventXML xml null, --事件xml
databaseName nvarchar(255) null, --数据库名称
SchemaName nvarchar(255) null, --架构名
ObjectName nvarchar(255) null, --用户
HostName varchar(64) null, --计算机名称
IPAddress varchar(32) null, --IP地址
ProgramName nvarchar(255) null, --SQLServer版本
LoginName nvarchar(255) null --登录名
)
go
--第二步:在需要监控的库上执行这个脚本,对DDL操作会记录在第一步中的库中
if exists(select * from sys.triggers where parent_class_desc= 'database' AND name = N'DDLtriggertTrace')
disable trigger DDLtriggertTrace on database
if exists(select * from sys.triggers where parent_class_desc= 'database' AND name = N'DDLtriggertTrace')
drop trigger DDLtriggertTrace on database
go
create trigger DDLtriggertTrace on database
--捕获函数、存储过程、视图、表的创建、修改、删除动作
for create_function,alter_function, create_procedure, alter_procedure, drop_procedure, create_view,
alter_view, drop_view, create_table, alter_table, drop_table
as
begin
set nocount on ;
declare @EventData xml = eventdata() ;--返回有关服务器或数据库事件的信息,以xml格式保存。
--rollback; --如果是执行删除动作 直接自动回滚,取消删除
declare @ip varchar(32) =( select client_net_address
from sys.dm_exec_connections
where session_id = @@SPID
) ;
insert AuditDB.dbo.DDLEvents
( EventType ,
EventDDL,
EventXML,
databaseName,
SchemaName,
ObjectName,
HostName,
IPAddress,
ProgramName,
LoginName
)
select @EventData.value('(/EVENT_INSTANCE/EventType)[1]','NVARCHAR(100)') ,
@EventData.value('(/EVENT_INSTANCE/TSQLCommand)[1]','NVARCHAR(MAX)') ,
@EventData ,
DB_NAME() ,
@EventData.value('(/EVENT_INSTANCE/SchemaName)[1]','NVARCHAR(255)') ,
@EventData.value('(/EVENT_INSTANCE/ObjectName)[1]','NVARCHAR(255)') ,
HOST_NAME() ,
@ip ,
PROGRAM_NAME() ,
SuseR_SNAME() ;
end
go
最后在写个代码对比工具,SQL存储过程编写就可以实现SVN的功能
对比功能参考:https://www.cnblogs.com/weifeng123/p/9900023.html
SQL 自动记录存储过程,表,函数的创建修改和删除 -相当于SVN一样的更多相关文章
- 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...
- sql的存储过程实例--循环动态创建表
创建一个存储过程,动态添加100张track表表名track_0 ~~ track_99注:sql的拼接只能用 CONCAT()函数 -- 创建一个存储过程 CREATE PROCEDURE crea ...
- Oracle数据库—— 存储过程与函数的创建
一.涉及内容 1.掌握存储过程与函数的概念. 2.能够熟练创建和调用存储过程与函数. 二.具体操作 1.创建存储过程,根据职工编号删除scott.emp表中的相关记录. (1)以scott 用户连接数 ...
- Sql Server存储过程和函数浅谈
今天给大家总结一下sql server中的存储过程和函数.本人是小白,里面内容比较初级,大神不喜勿喷 自行飘过就是.. 首先给大家简单列出sql server中的流控制语句,后面会用到的^_^ sql ...
- 面试问题 - SQL 中存储过程与函数的区别
SQL 中的存储过程与函数没有本质上的区别 函数 -> 只能返回一个变量. 函数可以嵌入到sql中使用, 可以在select 中调用, 而存储过程不行. 但函数也有着更多的限制,比如不能使用临 ...
- SQL中存储过程和函数的区别
转:https://www.cnblogs.com/jacketlin/p/7874009.html 本质上没区别.只是函数有如:只能返回一个变量的限制.而存储过程可以返回多个. 而函数是可以嵌入在s ...
- sql server 笔记(数据类型/新建、修改、删除数据表/)
1.数据类型: Character 字符串 / Unicode 字符串 / Binary 类型 / Number 类型 / Date 类型 / 其他数据类型 详解:http://www.w3sc ...
- db2 中 SQL判断物理表是否存在、修改表名
1.db2 中 SQL判断物理表是否存在 SELECT * FROM SYSIBM.SYSTABLES WHERE TID <> 0 AND Name = 'TABLE_NAME' AND ...
- MySQL使用SQL操作数据表的增加、修改和删除
表的修改和删除 修改 -- 修改表名称 -- ALTER TABLE 旧表名 RENAME AS 新表名 ALTER TABLE test RENAME AS test1 -- 增加表字段 -- AL ...
随机推荐
- 关于app夜间模式那点事
大半年没写过代码了 一直在忙一些其他的事情 这几天想起来看了一点 心惊肉跳的 发现好陌生 所以打算今后慢慢的拾起来 往深度和广度去发展 发现好久之前写的一个微博项目 有一个夜间模式的功能没有 ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J Press the Button
BaoBao and DreamGrid are playing a game using a strange button. This button is attached to an LED li ...
- EM_LGH CF965D Single-use Stones 思维_推理
Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 1000000 ...
- Pyhton学习——Day9(阶段性练习)
# 1.文件内容如下,标题为:姓名,性别,年纪,薪资## egon male 18 3000# alex male 38 30000# wupeiqi female 28 20000# yuanhao ...
- HDU 2300 Crashing Robots
Crashing Robots 题意 模拟多个机器人在四个方向的移动,检测crash robot, crash wall, OK这些状态 这是个模拟题需要注意几点: 理解转变方向后移动多少米,和转动方 ...
- Python笔记26----正则表达式匹配
1.语法: 2.题目1:数据类型: 如果要选择 time 为2014-12-18那天的数据:采用正则化来处理 代码: import re regex = re.compile(r'^2014-12 ...
- SOAP扩展PHP轻松实现WebService
最近在一个PHP项目中对接外部接口涉及到WebService,搜索引擎上相关文章不是很多,找到的大都是引用一个号称很强大的开源软件 NuSOAP(下载地址:http://sourceforge.net ...
- BZOJ 2780 Sevenk Love Oimaster (后缀自动机+树状数组+dfs序+离线)
题目大意: 给你$n$个大串和$m$个询问,每次给出一个字符串$s$询问在多少个大串中出现过 好神的一道题 对$n$个大串建出广义$SAM$,建出$parent$树 把字符串$s$放到$SAM$里跑, ...
- 模板 FFT 快速傅里叶变换
FFT模板,原理不难,优质讲解很多,但证明很难看太不懂 这模板题在bzoj竟然是土豪题,服了 #include <cmath> #include <cstdio> #inclu ...
- google浏览器安装接口测试工具postman方法
Google安装postman: 未配好的文件下载(点击选择下面配好的直接用):下载 配置方法: 一:需要修改postman安装包中js/requester.js 和runner.js ,将其中的ai ...