sql >> Database teknologi >  >> RDS >> Sqlserver

TSQL - opret en lagret proc inde i en transaktionserklæring

prøv at udføre create procedure i EXEC('...') , sådan her:

Begin Try
Begin Transaction 
    -- do a bunch of add/alter tables here
    -- do a bunch of data manipulation/population here

    -- create a stored proc
  EXEC ('create procedure dbo.test
  as
  begin
    select * from some_table
  end')
Commit  
End Try
Begin Catch
    Rollback  
    Declare @Msg nvarchar(max)
    Select @Msg=Error_Message();
    RaisError('Error Occured: %s', 20, 101,@Msg) With Log;
End Catch

GO


  1. SQL Server navngivet instans med Visual Studio 2017 Installer-projekt

  2. Find SSIS-pakkens sidste ændring/implementeringsdato - SQL Server

  3. Brug af merge..output til at få kortlægning mellem source.id og target.id

  4. Hvad skal overvåges i MySQL 8.0