August 26, 2005 at 12:27 pm
Hello,
I would like to use a cursor to browse through a chosen sub-set of the databases residing on a single server. Within the cursor, I would like to use Information_Schema.columns to search the tables of that database for columns of a given name.
To use Information_Schema, the current database must be referenced. So I tried dynamically creating the "USE <database name> GO" statement and executing it with either EXEC and EXECUTESQL. This failed, and so did attempts to reference Information_Schema by writing something like
"<database_name_variable>..Information_Schema.columns" This produced an error message saying that there was no linked server named <database_name>
Is there a technique for dynamically using variables to move from one database to another within a query?
Elliott
August 26, 2005 at 12:32 pm
EXEC sp_MSForeachDB 'if ''?'' in (''master'',''model'',''msdb'',''pubs'') begin Select ''?'' as ExecutedIn end'
August 26, 2005 at 1:41 pm
Thanks Remi,
sp_MSForeachDB appears to scroll through the databases. But when I attempt to use Information_Schema.columns, the context appears to remain in Master. In other words the column names that are produced are from Master, not from Pubs (for instance).
I think SQL Server does not like to make it easy to dynamically switch the database context.
Elliott
August 26, 2005 at 1:56 pm
Forgot you didn't know that one .
EXEC sp_MSForeachDB 'if ''?'' in (''master'',''model'',''msdb'',''pubs'') begin Select O.Name as ObjectName, C.name as ColName from ?.dbo.SysObjects O inner join ?.dbo.SysColumns C on O.id = C.id where O.XType IN (''V'', ''U'') Order by O.Name, C.Colid end'
August 26, 2005 at 2:01 pm
You need to switch context as part of the sp_executesql statement. Try this:
declare @strSQL nvarchar(1000)
set @strSQL = N'use tempdb '
set @strSQL = @strSQL + N'select top 10 * from information_schema.columns'
exec sp_executesql @strSQL
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
August 26, 2005 at 5:39 pm
Thanks for the clarification, Remi. It worked fine.
And thanks for the tip on changing the context, Phil. Now I can script something like:
Set strSQL='USE ' + @db + ' '
to dynamically select a database to enter and to run the Information_Schema view from there.
Best regards,
Elliott
Viewing 6 posts - 1 through 5 (of 5 total)
You must be logged in to reply to this topic. Login to reply