Использование текущего имени базы данных в T-SQL имеет оператор Using - PullRequest
0 голосов
/ 17 мая 2010

У меня есть приложение, выполняющее операторы 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

и использую (USE [msdb]) передлюбой блок, и я хочу получить имя базы данных, чтобы заменить это @database_name=N'**Client5281**', на текущее имя базы данных вместо ([msdb]), которое я использую.

Я надеюсь, что я объяснил, что я хочу хорошо.

Ответы [ 3 ]

2 голосов
/ 17 мая 2010

Удалить все use [msdb], они не нужны. Поскольку сценарий полностью квалифицирует имя процедуры с помощью имени базы данных и имени схемы, нет необходимости использовать USE перед вызовом процедуры. Затем вы можете просто использовать @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
0 голосов
/ 18 мая 2010

, потому что я выполняю этот запрос из приложения vb.net, я использовал метод replace () для замены dbname на текущее dbname спасибо за все, что пытались мне помочь.

0 голосов
/ 17 мая 2010

Единственный способ сделать это - динамический 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, так как они ограничивают область видимости переменной.

...