?
Solved

How to use variable with use statement

Posted on 2009-05-08
6
Medium Priority
?
710 Views
Last Modified: 2012-05-06
Hello,

I have a script that I'm working on that uses a variable referencing the
database name (@DBName).  When I try to use this in the form of  "USE
@DBName", it doesn't work.  If I use an nvarchar datatype and create a
string (like the following);

DECLARE @SQL nvarchar(2000)
DECLARE @DBName nvarchar(200)

SET @DBName='TestDatabase'

SET @SQL = 'USE ' + @DBName
EXEC sp_sqlexec @SQL

The script runs, but the script remains focused on the master.

Is there any way to specify USE with a variable?

Thanks!
Rick
0
Comment
Question by:RIVAGHI
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
6 Comments
 
LVL 75

Assisted Solution

by:Aneesh Retnakaran
Aneesh Retnakaran earned 400 total points
ID: 24341797
the dynamic sql has a different scope, and the scope come back to the current db; so whatever you need to accomplish to be done on  the other db, you should put those script inside that @sql variable and run it
0
 
LVL 31

Accepted Solution

by:
RiteshShah earned 480 total points
ID: 24341927
you can't change focus but yes, you can do your task as Aneesh said, have a look at following script.
 though you are in MASTER database but can get results of Adventureworks database.


USE MASTER
go
 
DECLARE @SQL nvarchar(2000)
DECLARE @DBName nvarchar(200)
 
SET @DBName='ADVENTUREWORK'
 
SET @SQL = 'USE ' + @DBName + ';'
SET @SQL = 'SELECT * FROM SYS.OBJECTS'
EXEC sp_sqlexec @SQL

Open in new window

0
 
LVL 41

Assisted Solution

by:Sharath
Sharath earned 480 total points
ID: 24342058
In Ritesh code, you can try like this. Slightly modified his code for your requirement.

USE MASTER
go
 
DECLARE @SQL nvarchar(2000)
DECLARE @DBName nvarchar(200)
 
SET @DBName='AdventureWorks'
SET @SQL = 'USE ' + @DBName + ' SELECT * FROM SYS.Objects'
EXEC sp_sqlexec @SQL
 
You can also try with three part name.

USE MASTER
go
 
DECLARE @SQL nvarchar(2000)
DECLARE @DBName nvarchar(200)
 
SET @DBName='AdventureWorks'
SET @SQL = ' SELECT * FROM + @DBName + '.SYS.Objects'
EXEC sp_sqlexec @SQL
 
0
Microsoft Certification Exam 74-409

Veeam® is happy to provide the Microsoft community with a study guide prepared by MVP and MCT, Orin Thomas. This guide will take you through each of the exam objectives, helping you to prepare for and pass the examination.

 
LVL 42

Assisted Solution

by:pcelba
pcelba earned 400 total points
ID: 24343280
All the above written by Sharath is correct. If you really need to swith the database then you have to do it explicitly. Let suppose your database count is not infinite, so the only solution is:


DECLARE @DBName nvarchar(200)
SET @DBName='YourDatabase'
 
IF @DBName = 'Master'
   USE Master
ELSE IF @DBName = 'Model'
   USE Model
ELSE IF @DBName = 'YourDatabase'
   USE YourDatabase
ELSE
   PRINT "Invalid Database name"
 
-- Remember the USE statement is not allowed in stored procedures, functions, and triggers

Open in new window

0
 
LVL 75

Assisted Solution

by:Anthony Perkins
Anthony Perkins earned 240 total points
ID: 24344001
You can also preface all objects with the database name and owner, that way you do not have to change databases.  This also means you would have to enable cross database ownership chaining.
0
 

Author Comment

by:RIVAGHI
ID: 24404500
Thank you all !!
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

When writing XML code a very difficult part is when we like to remove all the elements or attributes from the XML that have no data. I would like to share a set of recursive MSSQL stored procedures that I have made to remove those elements from …
In this article I will describe the Backup & Restore method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
Monitoring a network: how to monitor network services and why? Michael Kulchisky, MCSE, MCSA, MCP, VTSP, VSP, CCSP outlines the philosophy behind service monitoring and why a handshake validation is critical in network monitoring. Software utilized …
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

764 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question