sql >> Databáze >  >> RDS >> Sqlserver

TSQL - vytvořte uložený proces uvnitř příkazu transakce

zkuste provést create procedure v EXEC('...') , takto:

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. Převod Varchar na číslo pro řazení

  2. Strategie fondu připojení:dobrá, špatná nebo ošklivá?

  3. SQL Server Vytvořit index zobrazení, který obsahuje odlišné nebo seskupit podle

  4. Změňte krok auto_increment přírůstek polí o