1.The use of function merge(update.insert.delete) Example: #1.Initialize the data create table #test(id int ,value int); create table #test2(id int ,value int); insert into #test values(0,0) insert into #test values(1,1) insert into #test values(2,2)
下面直接上代码(copy到你的数据库里面直接就可以运行): CREATE PROCEDURE [dbo].[SP_UPDATE_LOG] ) AS BEGIN SET NOCOUNT ON; IF NOT EXISTS(SELECT * FROM sys.tables WHERE NAME = @TABLENAME AND TYPE = 'U' ) BEGIN PRINT'ERROR:not exist table '+@TABLENAME RETURN END IF (@TABLENAME L
insert into test_tb output inserted.id,inserted.data values('c'),('d') delete from test_tb output deleted.id where data='c' update test_tb set data='abc' output inserted.id as ID ,deleted.data as old_data ,inserted.data as new_data where data='c' wit
在存储过程的编写中难免会遇到调用同库他人的proc和跨库调用proc,还有一个proc中有多条对多表进行写入和修改的语句.那么就会用到tran. 如果我们在不写try的情况下就要对每个insert,update的后面写上 BEGIN ROLLBACK TRAN END 来确保所有语句的正常执行和有影响的行数. 而在写了try的情况下,我们就可规范一下写法,利用RAISERROR ) ) DECLARE @nResult INT ) BEGIN TRY BEGIN TRAN BEGIN SET @