在项目开发过程中,项目管理者通常都很希望对项目的开发进展有一个日志的记录。代码的记录和管理可以通过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一样的更多相关文章

  1. 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据

    使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...

  2. sql的存储过程实例--循环动态创建表

    创建一个存储过程,动态添加100张track表表名track_0 ~~ track_99注:sql的拼接只能用 CONCAT()函数 -- 创建一个存储过程 CREATE PROCEDURE crea ...

  3. Oracle数据库—— 存储过程与函数的创建

    一.涉及内容 1.掌握存储过程与函数的概念. 2.能够熟练创建和调用存储过程与函数. 二.具体操作 1.创建存储过程,根据职工编号删除scott.emp表中的相关记录. (1)以scott 用户连接数 ...

  4. Sql Server存储过程和函数浅谈

    今天给大家总结一下sql server中的存储过程和函数.本人是小白,里面内容比较初级,大神不喜勿喷 自行飘过就是.. 首先给大家简单列出sql server中的流控制语句,后面会用到的^_^ sql ...

  5. 面试问题 - SQL 中存储过程与函数的区别

    SQL 中的存储过程与函数没有本质上的区别 函数 -> 只能返回一个变量. 函数可以嵌入到sql中使用, 可以在select 中调用, 而存储过程不行.  但函数也有着更多的限制,比如不能使用临 ...

  6. SQL中存储过程和函数的区别

    转:https://www.cnblogs.com/jacketlin/p/7874009.html 本质上没区别.只是函数有如:只能返回一个变量的限制.而存储过程可以返回多个. 而函数是可以嵌入在s ...

  7. sql server 笔记(数据类型/新建、修改、删除数据表/)

    1.数据类型: Character 字符串 / Unicode 字符串 / Binary 类型 / Number 类型  /  Date 类型  / 其他数据类型 详解:http://www.w3sc ...

  8. db2 中 SQL判断物理表是否存在、修改表名

    1.db2 中 SQL判断物理表是否存在 SELECT * FROM SYSIBM.SYSTABLES WHERE TID <> 0 AND Name = 'TABLE_NAME' AND ...

  9. MySQL使用SQL操作数据表的增加、修改和删除

    表的修改和删除 修改 -- 修改表名称 -- ALTER TABLE 旧表名 RENAME AS 新表名 ALTER TABLE test RENAME AS test1 -- 增加表字段 -- AL ...

随机推荐

  1. Android实现图片相似度

    Android实现图片相似度 最近公司有一个需求,就是希望能判断用户提交的照片是否是身份证的正面或者反面.可以通过预设一张拍摄清晰的身份证正面或者反面,来对比是否相似,那么问题就转化为如何计算两张图片 ...

  2. SQL like查询条件中的通配符处理

    1. SQL like对时间查询的处理方法 SQL数据表中有savetime(smalldatetime类型)字段,表中有两条记录,savetime值为:2005-3-8 12:12:00和2005- ...

  3. JSP Java服务器页面

    大家好!好久不见!今日我们开始学习JSP了,一些记录基础性的知识在这里与大家分享. 先说下URL(Uniform Resource Locator 统一资源定位符). URL包括传输协议(http:/ ...

  4. css3之BFC、IFC、GFC和FFC

    CSS2.1中只有BFC和IFC, CSS3中才有GFC和FFC. What's FC?一定不是KFC,FC的全称是:Formatting Contexts,是W3C CSS2.1规范中的一个概念.它 ...

  5. centos7下安装pyspark

    1.安装python 2.安装jdk 3.下载spark:http://spark.apache.org/downloads.html, 下载新版(spark-2.3.1-bin-hadoop2.7. ...

  6. [USACO 2009 Feb Gold] Fair Shuttle (贪心+优先队列)

    题目大意:有N个站点的轻轨站,有一个容量为C的列车起点在1号站点,终点在N号站点,有K组牛群,每组数量为Mi(1≤Mi≤N),行程起点和终点分别为Si和Ei(1≤Si<Ei≤N).计算最多有多少 ...

  7. PHP中的 Iterator 与 Generator

    在讲解生成器之前先介绍一下迭代器: 在 PHP 中,通常情况下遍历数组使用 foreach 来遍历. 如果我们要想让一个对象可以遍历呢? PHP 为我们提供了 Iterator 接口,只要实现了这个接 ...

  8. vue 表格数据编辑,点击取消或者完成按钮后,关闭编辑状态没有及时生效

    点击编辑按钮: 编辑状态下,表格可以编辑.但是点击“确认”或者“取消”按钮,列数据编辑状态已经修改,但是视图没有改变. 页面代码: 获取当前行的index,并直接修改当前行用于判断是否编辑状态的数据为 ...

  9. Python 绘图与可视化 seaborn

    Seaborn是一个基于matplotlib的Python数据可视化库.它提供了一个高级界面,用于绘制有吸引力且信息丰富的统计图形. 主页:http://seaborn.pydata.org/ 官方教 ...

  10. java静态方法

    静态方法(全局方法)不能访问this(当前对象)它和类没有关系,会有逻辑错误,当调用静态方法的时候不需要创建对象 可以直接为boolean result = MyTest.isPrime();直接访问 ...