在T-SQL中使用当前数据库名称具有Using语句

时间:2010-05-17 15:57:58

标签: sql-server sql-server-agent

我有应用程序运行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])并且我想获取数据库名称以使用当前数据库名称而不是我正在使用的([msdb])替换此@database_name=N'**Client5281**',

我希望我能解释我想要的东西。

3 个答案:

答案 0 :(得分:2)

删除所有use [msdb],不需要它们。由于脚本使用db名称和模式名称完全限定过程名称,因此在调用过程之前无需使用USE。然后,您只需使用@database_name=DB_NAME ()

另一种解决方案是使用SQLCMD变量,SSMS在properly configured时识别:

: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

答案 1 :(得分: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语句,因为这些语句限制了变量范围。

答案 2 :(得分:0)

因为我从vb.net应用程序执行此查询,所以我使用replace()方法用当前的dbname替换dbname。感谢所有人试图帮助我。