"Nothing has changed" - Determining when a procedure has been altered
As a consultant, I regularly need to determine when a stored procedure was last altered. Without having implemented a series of DDL triggers, how can this be accomplished?
In Microsoft SQL Server, you can easily retrieve this information from the sys.procedures catalog view. The following query demonstrates this.
SELECT
[name]
,modify_date
,create_date
,*
FROM
sys.procedures
Of course you can take it a step further by limiting the results to a period of time where you know that no changes should have been made. For example, the following query lists all stored procedures that have been changed since August 1, 2007 (the time I last visited this client).
SELECT
[name]
,modify_date
,create_date
,*
FROM
sys.procedures
WHERE
modify_date > '2007-08-01'
Although, using this technique will not allow me to identify who made the change, I can at least determine that a change has taken place.
Cheers!
Joe
Legacy Comments
Tom
2007-08-30 |
re: "Nothing has changed" - Determining when a procedure has been altered Handy, thanks. |
Chris Pietschmann
2007-09-08 |
re: "Nothing has changed" - Determining when a procedure has been altered Nice tip! Thanks. |
Gregor Suttie
2007-09-10 |
re: "Nothing has changed" - Determining when a procedure has been altered Note this only works on SQL 2005 - this wont work in sql 2000 or before. The modify date was never updated in earlier versions which meant you couldnt use get the last modified date. Works great in sql 2005 thanks for that - I use Red gates sql compare tool which simplifies everything you could ever want for database releases and such like. |
Patrick Spence
2008-04-04 |
re: "Nothing has changed" - Determining when a procedure has been altered If you want to weed-out the stored procedures that come with SQL Server, use this: SELECT [name] , modify_date , create_date FROM sys.procedures WHERE is_ms_shipped = 0 |
Krishna
2008-07-03 |
re: "Nothing has changed" - Determining when a procedure has been altered Thanks a ton |
snow boots for women
2010-10-20 |
re: "Nothing has changed" - Determining when a procedure has been altered Of course you can take it a step further by limiting the results to a period of time where you know that no changes should have been made. For example, the following query lists all stored procedures that have been changed since August 1, 2007 (the time I last visited this client). snow boots | columbia jackets | mac makeup | the north face outlet |