sql >> データベース >  >> RDS >> Sqlserver

SQLServerジョブを自動的に作成する

    ジョブスクリプトを動的に作成して実行する必要があります。次のようにするか、ジョブの所有者とデータベース名の入力パラメータを使用してストアドプロシージャに変更することができます。

    DECLARE @JobName VARCHAR(20)  --Job Name
    DECLARE @Owner VARCHAR(200)   --Job Owner
    DECLARE @DBName VARCHAR(200)  --Database Name
    DECLARE @JobCode VARCHAR(4000) --Create Statement for Job
    SET @JobName = 'Test2'
    SET @Owner = 'BrianD'
    SET @DBName = 'master'
    SET @JobCode = 'USE msdb
    GO
    BEGIN TRANSACTION
    DECLARE @ReturnCode INT
    SELECT @ReturnCode = 0
    IF NOT EXISTS (SELECT name FROM msdb.dbo.syscategories WHERE name=N''[Uncategorized (Local)]'' AND category_class=1)
    BEGIN
    EXEC @ReturnCode = msdb.dbo.sp_add_category @class=N''JOB'', @type=N''LOCAL'', @name=N''[Uncategorized (Local)]''
    IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
    END
    DECLARE @jobId BINARY(16)
    EXEC @ReturnCode =  msdb.dbo.sp_add_job @job_name=N''' + @JobName + ''', 
            @enabled=1, 
            @notify_level_eventlog=0, 
            @notify_level_email=0, 
            @notify_level_netsend=0, 
            @notify_level_page=0, 
            @delete_level=0, 
            @description=N''No description available.'', 
            @category_name=N''[Uncategorized (Local)]'', 
            @owner_login_name=N''' + @Owner + ''', @job_id = @jobId OUTPUT
    IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
    EXEC @ReturnCode = msdb.dbo.sp_add_jobstep @[email protected], @step_name=N''Version and Prod Level'', 
            @step_id=1, 
            @cmdexec_success_code=0, 
            @on_success_action=1, 
            @on_success_step_id=0, 
            @on_fail_action=2, 
            @on_fail_step_id=0, 
            @retry_attempts=0, 
            @retry_interval=0, 
            @os_run_priority=0, @subsystem=N''TSQL'', 
            @command=N''select SERVERPROPERTY(''''productversion''''), SERVERPROPERTY(''''productlevel'''')'', 
            @database_name=N''' + @DBName + ''', 
            @flags=0
    IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
    EXEC @ReturnCode = msdb.dbo.sp_update_job @job_id = @jobId, @start_step_id = 1
    IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
    EXEC @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @jobId, @server_name = N''(local)''
    IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
    COMMIT TRANSACTION
    GOTO EndSave
    QuitWithRollback:
        IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION
    EndSave:
    GO'
    Exec (@JobCode)
    

    うまくいけば、これはあなたが正しい方向に進むようになるでしょう。さらにサポートが必要な場合はお知らせください。



    1. ORA-30926:ソース表で安定した行のセットを取得できません

    2. TRY_CONVERT()がSQLServerでどのように機能するか

    3. MySQL COALESCE()の説明

    4. ORDER BY句は、ビュー、インライン関数、派生テーブル、サブクエリ、および一般的なテーブル式では無効です。