使用游标循环查询多个数据库

时间:2014-07-10 21:59:36

标签: sql-server cursors

我试图通过我在表中列出的多个数据库循环查询,我尝试使用游标并使用新的数据库名称切换出USE语句,但我不断收到错误的语法错误。有没有办法做到这一点?以下是我的尝试。

Declare @storednamesDATABASE varchar(255)
Declare storednamesDBs_cursor Cursor
for
select Database_name from ##ALLTHEstorednames

Open storednamesDBs_cursor
Fetch next from storednamesDBs_cursor into @storednamesDATABASE
WHILE @@FETCH_STATUS = 0 BEGIN

Use @storednamesDATABASE
select distinct a.database_id, c.name as Database_Name, a.object_id, b.name as Table_Name,
dateadd(day, datediff(day, 0, getdate()),0) as Use_Date
from sys.dm_db_index_usage_stats a
join sys.all_objects b
on a.object_id = b.object_id
join sys.databases c
on a.database_id = c.database_id
where (a.last_user_seek between dateadd(hour, -24, CURRENT_TIMESTAMP) AND CURRENT_TIMESTAMP
or a.last_user_scan between dateadd(hour, -24, CURRENT_TIMESTAMP) AND CURRENT_TIMESTAMP
or a.last_user_lookup between dateadd(hour, -24, CURRENT_TIMESTAMP) AND CURRENT_TIMESTAMP)
and b.type = 'u'


End
Close storednamesDBs_cursor

1 个答案:

答案 0 :(得分:0)

首先,如果你是天蓝色的,你不能使用“使用”

您的问题是“使用”不会采用字符串(nvarchar)来获取对象名称。

要实现这一目标,您可以使用动态SQL

Select @Sql = 'Use ' + @storednamesDATABASE + ';  --Other SQL Here'
Exec sp_executesql @Sql

虽然您将不得不将其余的查询放在Sql字符串中,因为它不会更改您当前所在的连接。它有效地创建了一个存储过程并运行它。

要将参数传递给查询,您可以使用类似

的内容
Exec sp_executesql @Sql, N'@Var1 int, @Var2 nvarchar(50)', @Var1 = @SomeVar, @Var2 = 'Test'