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 ...
随机推荐
- Linux常见后缀缩写含义
ctl: control rc: run control (A run-control file is a file of declarations or commands associated wi ...
- 如何使用pgpool failover_stream.sh自己控制选择指定的master节点
集群架构: h236:master h237:standby sync h238:standby sync h239:stadnby async h240:standby async h241:sta ...
- 跟着8张思维导图学习javascript (转)
学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将po出8张javascript相关的思维导图. 思维导图小tips:思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ,它简单却又 ...
- JS判断客户端是否是iOS或者Android或者ipad(二)
js判断客户端是IPAD和iphone 多了就不说了,直接上代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 funct ...
- -ms-,-moz-,-webkit-,-o-含义及各浏览器内核整理
transform:rotate(30deg); //统一标识语句 -ms-transform:rotate(30deg); //-ms代表ie内核识别码 ...
- centos7下安装pyspark
1.安装python 2.安装jdk 3.下载spark:http://spark.apache.org/downloads.html, 下载新版(spark-2.3.1-bin-hadoop2.7. ...
- pytorch 6 build_nn_quickly 快速搭建神经网络
import torch import torch.nn.functional as F # replace following class code with an easy sequential ...
- 上机题目(0基础)-计算两个正整数的最大公约数和最小公倍数(Java)
题目例如以下:
- UVALive - 2031 Dance Dance Revolution 三维dp
题目大意:有一个胖子在玩跳舞机.刚開始的位置在(0,0).跳舞机有四个方向键,上左下右分别相应1,2,3,4.如今有下面规则 1.假设从0位置移动到随意四个位置,消耗能量2 2.假设从非0位置跳到相邻 ...
- yqj2065经典语录
在上课时.博客中和<编程导论(Java)>书中,yqj2065说过一些简短的话.列举一些玩玩. 假设您在我的博客中看见好玩的,最好还是推荐一下. 持续加入中... 1. "噢姐姐 ...