Today’s post comes directly from a conversation with a close friend of mine who is a developer. Since developers deploy changes often, they need to know what order to execute their changes in.
The answer is yes, but there’s a catch
By default, normal stored procedures don’t prevent you from dropping a table. Let’s look at a demo.
SELECT *
INTO TestTable
FROM sys.messages
GO
INSERT INTO TestTable
SELECT * FROM sys.messages
GO 10
That should give us plenty of junk data. Now we need a procedure, so let’s SELECT * from that new table.
CREATE PROCEDURE [Query_TestTable] as
BEGIN
SELECT * FROM TestTable
END
GO
Now we just need to drop the table.
data:image/s3,"s3://crabby-images/85a8b/85a8b294b1bebc21da1579e6ef6f821d13b97b81" alt=""
Once we drop the table, the stored procedure returns an error.
data:image/s3,"s3://crabby-images/bb91f/bb91f854ef522bfcf1d900bbfcc48868c55e181a" alt=""
But I said there’s a catch. The catch is if the stored procedure is currently running, you can’t drop the procedure.
First, re-run the script to create the table and insert some rows.
Second, start running the procedure. Then run the drop table command and watch it wait. I’ll use sp_WhoIsActive to take a look at the current running processes.
data:image/s3,"s3://crabby-images/0fd7e/0fd7e0aab79c8901fa80de5e056b86c0a8acda4e" alt=""
LCK_M_X (sound familiar?)
It looks a lot like LCK_M_SCH_S, which I previously blogged about here.
In this case, the X stands for exclusive. Before we can drop the table, the stored procedure has to finish using the table.
Thanks for reading! Stay tuned.