Share via


sp_add_jobserver (Transact-SQL)

將指定作業的目標鎖定在指定的伺服器上。

主題連結圖示Transact-SQL 語法慣例

語法

sp_add_jobserver [ @job_id = ] job_id | [ @job_name = ] 'job_name'
     [ , [ @server_name = ] 'server' ] 

引數

  • [@job_id = ] job_id
    作業的識別碼。job_id 是 uniqueidentifier,預設值是 NULL。

  • [@job_name = ] 'job_name'
    作業的名稱。job_name 是 sysname,預設值是 NULL。

    [!附註]

    您必須指定 job_id 或 job_name,但不能同時指定這兩者。

  • [@server_name = ] 'server'
    作業的目標伺服器名稱。server 是 nvarchar(30),預設值是 N'(LOCAL)'。server可以是 (LOCAL),代表本機伺服器,也可以是現有目標伺服器的名稱。

傳回碼值

0 (成功) 或 1 (失敗)

結果集

備註

@automatic_postsp_add_jobserver 中,但並未列在「引數」之下。保留 @automatic_post,供內部使用。

SQL Server Management Studio 提供了一種簡單的圖形方式供您管理各項作業,建議您利用這個方式來建立和管理作業基礎結構。

權限

依預設,只有系統管理員 (sysadmin) 固定伺服器角色的成員,才能夠執行這個預存程序。其他使用者必須被授與 msdb 資料庫的下列其中一個 SQL Server Agent 固定資料庫角色。

  • SQLAgentUserRole

  • SQLAgentReaderRole

  • SQLAgentOperatorRole

如需有關這些角色權限的詳細資料,請參閱<SQL Server Agent 固定資料庫角色>。

只有 系統管理員 (sysadmin) 固定伺服器角色的成員能夠針對包含多部伺服器的作業來執行 sp_add_jobserver

範例

A. 將作業指派給本機伺服器

下列範例會指派 NightlyBackups 作業,讓它在本機伺服器中執行。

[!附註]

這個範例假設 NightlyBackups 作業已在執行中。

USE msdb ;
GO

EXEC dbo.sp_add_jobserver
    @job_name = N'NightlyBackups' ;
GO

B. 指派作業,使它在不同的伺服器中執行

下列範例會將多伺服器作業 Weekly Sales Backups 指派給 SEATTLE2 伺服器。

[!附註]

這個範例假設 Weekly Sales Backups 作業已存在,且 SEATTLE2 已註冊為目前執行個體的目標伺服器。

USE msdb ;
GO

EXEC dbo.sp_add_jobserver
    @job_name = N'Weekly Sales Backups',
    @server_name = N'SEATTLE2' ;
GO