0

アプリケーションでT-SQLステートメントを実行して、複数のデータベースを更新しています。問題は、次のt-sqlを使用していることです。

USE [msdb]
GO
DECLARE @jobId BINARY(16)
EXEC  msdb.dbo.sp_add_job @job_name=N'test2', 
        @enabled=1, 
        @start_step_id=1, 
        @notify_level_eventlog=0, 
        @notify_level_email=2, 
        @notify_level_netsend=2, 
        @notify_level_page=2, 
        @delete_level=0, 
        @description=N'', 
        @category_name=N'[Uncategorized (Local)]', 
        @owner_login_name=N'sa', 
        @notify_email_operator_name=N'', 
        @notify_netsend_operator_name=N'', 
        @notify_page_operator_name=N'', @job_id = @jobId OUTPUT
select @jobId
GO
EXEC msdb.dbo.sp_add_jobserver @job_name=N'test2', @server_name = N'AMR-PC\SQL2008'
GO
USE [msdb]
GO
EXEC msdb.dbo.sp_add_jobstep @job_name=N'test2', @step_name=N'test', 
        @step_id=1, 
        @cmdexec_success_code=0, 
        @on_success_action=1, 
        @on_fail_action=2, 
        @retry_attempts=0, 
        @retry_interval=0, 
        @os_run_priority=0, @subsystem=N'TSQL', 
        @command=N'EXEC sp_MSforeachdb ''
    EXEC sp_MSforeachtable @command1=''''DBCC DBREINDEX (''''''''*'''''''')'''', 
        @replacechar=''''*''''''', 
        @database_name=N'Client5281', 
        @output_file_name=N'C:\Documents and Settings\Amr\Desktop\Scheduel Reports\report', 
        @flags=2
GO

USE [msdb]
GO
DECLARE @schedule_id int
EXEC msdb.dbo.sp_add_jobschedule @job_name=N'test2', @name=N'test', 
        @enabled=1, 
        @freq_type=8, 
        @freq_interval=1, 
        @freq_subday_type=1, 
        @freq_subday_interval=0, 
        @freq_relative_interval=0, 
        @freq_recurrence_factor=1, 
        @active_start_date=20100517, 
        @active_end_date=99991231, 
        @active_start_time=0, 
        @active_end_time=235959, @schedule_id = @schedule_id OUTPUT
select @schedule_id
GO

@database_name=N'**Client5281**',ブロックの前に(USE [msdb])を使用していて、データベース名を取得して、これを使用している([msdb])ではな​​く現在のデータベース名に置き換えたいと考えています。

私が欲しいものをうまく説明したことを願っています。

4

3 に答える 3

2

すべて削除しuse [msdb]ます。不要です。スクリプトはプロシージャ名をデータベース名とスキーマ名で完全に修飾するため、プロシージャを呼び出す前に使用する必要はありません。その後、単にを使用できます@database_name=DB_NAME ()

別の解決策は、SQLCMD変数を使用することです。これは、適切に構成されたときにSSMSが認識します。

:setvar dbname Client5281
...
USE [msdb]
GO
EXEC msdb.dbo.sp_add_jobstep @job_name=N'test2', @step_name=N'test', 
        ...
        @database_name=N'$(dbname)', 
        ...
GO
于 2010-05-17T17:30:37.187 に答える
0

そのための唯一の方法は動的SQLです。例えば:

declare @sql nvarchar(max)
set @sql = N'use ' + @database_name + '
    go
    declare @schedule_id int
    ...'
exec (@sql)

コメントに応じて、次のように現在のデータベース名を保存できます。

declare @db varchar(256)
set @db = DB_NAME()

そして変更します:

@database_name=N'Client5281', 

に:

@db,

goまた、ステートメントは変数のスコープを制限するため、ステートメントを削除する必要があります。

于 2010-05-17T16:07:13.570 に答える
0

vb.netアプリケーションからこのクエリを実行するため、replace()メソッドを使用してdbnameを現在のdbnameに置き換えました。私を助けようとしたすべての人に感謝します。

于 2010-05-18T16:02:38.477 に答える