sqlserver 使用腳本建立做業

  1. --【做業經常使用的幾個步驟】  
  2. EXEC msdb.dbo.sp_delete_job  
  3. EXEC msdb.dbo.sp_add_job  
  4. EXEC msdb.dbo.sp_add_jobstep  
  5. EXEC msdb..sp_add_jobschedule  
  6. EXEC msdb.dbo.sp_add_jobserver   
  7. EXEC msdb.dbo.sp_start_job  
  8.   
  9.   
  10.   
  11. --刪除做業  
  12. IF  EXISTS (SELECT JOB_ID FROM MSDB.DBO.SYSJOBS_VIEW WHERE NAME =N'做業名稱')   
  13. EXECUTE MSDB.DBO.SP_DELETE_JOB @JOB_NAME=N'做業名稱'   
  14.   
  15. --定義建立做業  
  16. DECLARE @jobid uniqueidentifier  
  17. EXEC msdb.dbo.sp_add_job  
  18.         @job_name = N'做業名稱',  
  19.         @job_id = @jobid OUTPUT  
  20.   
  21. --定義做業步驟  
  22. DECLARE @sql nvarchar(400),@dbname sysname  
  23. SELECT  @dbname=DB_NAME(), --執行的數據庫(當前)  
  24.         @sql=N'做業步驟內容' --通常定義的是使用TSQL處理的做業,這裏定義要執行的Transact-SQL語句  
  25. EXEC msdb.dbo.sp_add_jobstep  
  26.         @job_id = @jobid,  
  27.         @step_name = N'做業步驟名稱',  
  28.         @subsystem = 'TSQL', --步驟的類型,通常爲TSQL  
  29.         @database_name=@dbname,  
  30.         @command = @sql  
  31.   
  32. --建立調度(使用後面專門定義的幾種做業調度模板)  
  33. EXEC msdb..sp_add_jobschedule  
  34.         @job_id = @jobid,  
  35.         @name = N'調度名稱',  
  36.         @freq_type=4,                --天天  
  37.         @freq_interval=1,            --指定每多少天發生一次,這裏是1天.  
  38.         @freq_subday_type=0x8,       --重複方式,0x1=在指定的時間,0x4=多少分鐘,0x8=多少小時執行一次  
  39.         @freq_subday_interval=1,     --重複週期數,這裏每小時執行一次  
  40.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  41.         @active_end_date = 99991231, --做業執行的中止日期,默認爲99991231,格式爲YYYYMMDD  
  42.         @active_start_time = 00000, --做業執行的開始時間,格式爲HHMMSS  
  43.         @active_end_time = 235959    --做業執行的中止時間,格式爲HHMMSS  
  44.   
  45. --添加目標服務器  
  46. DECLARE @servername sysname  
  47. SET @servername=CONVERT(nvarchar(128),SERVERPROPERTY(N'ServerName'))--當前SQL實例  
  48. EXEC msdb.dbo.sp_add_jobserver   
  49.         @job_id = @jobid,  
  50.         @server_name = @servername   
  51.   
  52. -----------------------------------------------------------------------------------------------  
  53. --調度模板定義 sp_add_jobschedule  
  54.   
  55. --只執行一次的做業調度  
  56. EXEC msdb..sp_add_jobschedule  
  57.         @job_id = @jobid,  
  58.         @name = N'調度名稱',  
  59.         @freq_type=1,                --僅執行一次  
  60.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  61.         @active_start_time = 00000   --做業執行的開始時間,格式爲HHMMSS  
  62.   
  63. --日調度  
  64. EXEC msdb..sp_add_jobschedule  
  65.         @job_id = @jobid,  
  66.         @name = N'調度名稱',  
  67.         @freq_type=4,                --天天  
  68.         @freq_interval=1,            --指定每多少天發生一次,這裏是1天.  
  69.         @freq_subday_type=0x8,       --重複方式,(0x1=指定的時間;0x4=多少分鐘;0x8=多少小時)執行一次  
  70.         @freq_subday_interval=1,     --重複週期數,這裏每小時執行一次  
  71.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  72.         @active_end_date = 99991231, --做業執行的中止日期,默認爲99991231,格式爲YYYYMMDD  
  73.         @active_start_time = 00000, --做業執行的開始時間,格式爲HHMMSS  
  74.         @active_end_time = 235959    --做業執行的中止時間,格式爲HHMMSS  
  75.   
  76. --周調度  
  77. EXEC msdb.dbo.sp_add_jobschedule  
  78.         @job_id = @jobid,  
  79.         @name = N'調度名稱',   
  80.         @freq_type = 8,              --每週  
  81.         @freq_recurrence_factor = 1, --每多少周執行一次,這裏是每週  
  82.         @freq_interval = 62,         --在星期幾執行,由POWER(2,N)表示,N的值爲0~6,表明星期日~星期六,若是指定兩個,則將值相加,例如,值爲65表示在星期天和星期日執行(POWER(2,0)+POWER(2,6))  
  83.         @freq_subday_type = 0x8,     --重複方式,0x1=在指定的時間,0x4=多少分鐘,0x8=多少小時執行一次  
  84.         @freq_subday_interval = 1,   --重複週期數,這裏每小時執行一次  
  85.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  86.         @active_end_date = 99991231, --做業執行的中止日期,默認爲99991231,格式爲YYYYMMDD  
  87.         @active_start_time = 00000, --做業執行的開始時間,格式爲HHMMSS  
  88.         @active_end_time = 235959    --做業執行的中止時間,格式爲HHMMSS  
  89.   
  90. --月調度(每X個月的每個月幾號)  
  91. EXEC msdb.dbo.sp_add_jobschedule  
  92.         @job_id = @jobid,  
  93.         @name = N'調度名稱',   
  94.         @freq_type = 16,             --每個月  
  95.         @freq_recurrence_factor = 2, --每多少月執行一次,這裏是每2個月  
  96.         @freq_interval = 2,          --在執行月的第幾天執行,這裏是第2天  
  97.         @freq_subday_type = 0x8,     --重複方式,0x1=在指定的時間,0x4=多少分鐘,0x8=多少小時執行一次  
  98.         @freq_subday_interval = 1,   --重複週期數,這裏每小時執行一次  
  99.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  100.         @active_end_date = 99991231, --做業執行的中止日期,默認爲99991231,格式爲YYYYMMDD  
  101.         @active_start_time = 00000, --做業執行的開始時間,格式爲HHMMSS  
  102.         @active_end_time = 235959    --做業執行的中止時間,格式爲HHMMSS  
  103.   
  104. --月調度(每X個月的相對時間)  
  105. EXEC msdb.dbo.sp_add_jobschedule  
  106.         @job_id = @jobid,  
  107.         @name = N'調度名稱',   
  108.         @freq_type = 32,             --每個月  
  109.         @freq_recurrence_factor = 2, --每多少月執行一次,這裏是每2個月  
  110.         @freq_interval = 9,          --在當月的那個時間執行,1~7=星期日至星期六,8=日 ,9=工做日,10=週末  
  111.         @freq_relative_interval = 1, --在第幾個相對時間執行,容許的值爲1,2,4,8表明第1~4個相對時間,16表示最後一個相對時間  
  112.         @freq_subday_type = 0x8,     --重複方式,0x1=在指定的時間,0x4=多少分鐘,0x8=多少小時執行一次  
  113.         @freq_subday_interval = 1,   --重複週期數,這裏每小時執行一次  
  114.         @active_start_date = NULL,   --做業執行的開始日期,爲NULL時表示當前日期,格式爲YYYYMMDD  
  115.         @active_end_date = 99991231, --做業執行的中止日期,默認爲99991231,格式爲YYYYMMDD  
  116.         @active_start_time = 00000, --做業執行的開始時間,格式爲HHMMSS  
  117.         @active_end_time = 235959    --做業執行的中止時間,格式爲HHMMSS  
  118.   
  119. --在特定時候執行的做業調度  
  120. EXEC msdb.dbo.sp_add_jobschedule  
  121.         @job_id = @jobid,  
  122.         @name = N'調度名稱',   
  123.         @freq_type = 64     --64=在SQLServerAgent 服務啓動時運行,128=計算機空閒時運行  
  124.   
  125. -----------------------------------------------------------------------------------------------  


 

 

[sql]  view plain  copy
 
    1. IF EXISTS (SELECT * FROM DBO.SYSOBJECTS WHERE ID = OBJECT_ID(N'[DBO].SP_AUTO_CREATEJOB') AND OBJECTPROPERTY(ID, N'ISPROCEDURE') = 1)  
    2. DROP PROCEDURE [DBO].SP_AUTO_CREATEJOB  
    3. GO  
    4.   
    5. CREATE PROCEDURE DBO.SP_AUTO_CREATEJOB  
    6.                         @DBNAME VARCHAR(100),    --執行數據庫     
    7.                         @JOBNAME VARCHAR(100),       
    8.                         @EXECSQL NVARCHAR(4000) --執行語句        
    9. AS       
    10. PRINT '----做業 :'+@JOBNAME  
    11. PRINT '----開始執行:'  +@EXECSQL  
    12.   
    13. BEGIN TRANSACTION     
    14. DECLARE     
    15.     @JOBID UNIQUEIDENTIFIER,         
    16.     @RETURNCODE INT      
    17.     SELECT @RETURNCODE = 0                
    18. BEGIN           
    19.     IF  EXISTS (SELECT JOB_ID FROM MSDB.DBO.SYSJOBS_VIEW WHERE NAME =@JOBNAME)   
    20.     EXECUTE MSDB.DBO.SP_DELETE_JOB @JOB_NAME=@JOBNAME   
    21.             
    22.     EXECUTE @RETURNCODE = MSDB.DBO.SP_ADD_JOB       --返回值:0成功,1失敗  
    23.                         @JOB_NAME = @JOBNAME,              
    24.                         @ENABLED = 1,               --狀態。默認值爲 1(啓用),爲 0 不啓用  
    25.                         @OWNER_LOGIN_NAME = 'SA',   --擁有做業的登陸名。默認值爲 NULL,可解釋爲當前登陸名  
    26.                         @JOB_ID = @JOBID OUTPUT                      
    27.     IF (@@ERROR <> 0 OR @RETURNCODE <> 0) GOTO QUITWITHROLLBACK    
    28.                      
    29.     EXECUTE @RETURNCODE = MSDB.DBO.SP_ADD_JOBSTEP   
    30.                         @JOB_ID = @JOBID,                
    31.                         @STEP_NAME = N'STEP1',      --步驟名稱     
    32.                         @SUBSYSTEM = 'TSQL',        --步驟的類型,通常爲TSQL           
    33.                         @DATABASE_NAME = @DBNAME,   --執行數據庫                
    34.                         @COMMAND = @EXECSQL         --執行語句               
    35.     IF (@@ERROR <> 0 OR @RETURNCODE <> 0) GOTO QUITWITHROLLBACK       
    36.                    
    37.     EXECUTE @RETURNCODE = MSDB.DBO.SP_UPDATE_JOB   
    38.                         @JOB_ID = @JOBID,                 
    39.                         @START_STEP_ID = 1          --做業中要執行的第一個步驟的標識號  
    40.     IF (@@ERROR <> 0 OR @RETURNCODE <> 0) GOTO QUITWITHROLLBACK   
    41.                              
    42.     EXECUTE @RETURNCODE = MSDB.DBO.SP_ADD_JOBSERVER   
    43.                         @JOB_ID = @JOBID,                     
    44.                         @SERVER_NAME = N'(LOCAL)'                           
    45.     IF (@@ERROR <> 0 OR @RETURNCODE <> 0) GOTO QUITWITHROLLBACK      
    46.           
    47. END   
    48. COMMIT TRANSACTION    
    49.      
    50. GOTO ENDSAVE    
    51.                         
    52. QUITWITHROLLBACK:           
    53.     IF (@@TRANCOUNT > 0)     
    54.     BEGIN          
    55.         ROLLBACK TRANSACTION          
    56.         RETURN 1    
    57.     END     
    58.          
    59. ENDSAVE:         
    60. EXEC @RETURNCODE = MSDB.DBO.SP_START_JOB @JOB_ID = @JOBID  --啓動做業   
    61. RETURN @RETURNCODE    
相關文章
相關標籤/搜索