Solved

How to use variable with use statement

Posted on 2009-05-08
6
661 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
6 Comments
 
LVL 75

Assisted Solution

by:Aneesh Retnakaran
Aneesh Retnakaran earned 100 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 120 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 40

Assisted Solution

by:Sharath
Sharath earned 120 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
Free Trending Threat Insights Every Day

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

 
LVL 41

Assisted Solution

by:pcelba
pcelba earned 100 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 60 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

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

I am showing a way to read/import the excel data in table using SQL server 2005... Suppose there is an Excel file "Book1" at location "C:\temp" with column "First Name" and "Last Name". Now to import this Excel data into the table, we will use…
INTRODUCTION: While tying your database objects into builds and your enterprise source control system takes a third-party product (like Visual Studio Database Edition or Red-Gate's SQL Source Control), you can achieve some protection using a sing…
This video shows how to remove a single email address from the Outlook 2010 Auto Suggestion memory. NOTE: For Outlook 2016 and 2013 perform the exact same steps. Open a new email: Click the New email button in Outlook. Start typing the address: …
This video explains how to create simple products associated to Magento configurable product and offers fast way of their generation with Store Manager for Magento tool.

757 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

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now