.NET Tutorials, Forums, Interview Questions And Answers
Welcome :Guest
 
Sign In
Register
 
Win Surprise Gifts!!!
Congratulations!!!


Top 5 Contributors of the Month
david stephan

Home >> Articles >> DataBase >> Post New Resource Bookmark and Share   

 Subscribe to Articles

What are temporary tables in Sql Server?

Posted By:Vishal Nayan       Posted Date: September 01, 2011    Points: 200    Category: DataBase    URL: http://www.dotnetspark.com  

What are temporary tables in Sql Server?
 

What are temporary tables in Sql Server?

 

Introduction: Temporary tables are a useful tool in SQL Server provided to allow for short term use of data .SQL Server provides the concept of temporary table which helps the developer in a great way. These tables can be created at runtime and can do the all kinds of operations that one normal table can do. But, based on the table types, the scope is limited. These tables are created inside tempdb database.

Types of temporary table:

1) Local temp table: Local temporary tables are only available to the current connection to the database for the current user and are dropped when the connection is closed. they are automatically deleted when the user disconnects from instances. Local temporary table name is stared with hash ("#") sign.

2) Global temp table: Global temporary tables are available to any connection once created, and are dropped when the last connection using it is closed. Global Temporary tables name starts with a double hash ("##"). Once this table has been created by a connection, like a permanent table it is then available to any user by any connection. It can only be deleted once all connections have been closed.

Before we start creating temp table, we need to keep below points in mind

  • Temporary table created on tempdb of SQL Server. This is a separate database. So, this is an additional overhead and can causes performance issues.
  • Number of rows and columns need to be as minimum as needed.
  • Tables need to be deleted when they are done with their work.

 

Create Local temp table

1. Using CREATE

 CREATE TABLE #LocalTempTable(

UserID int,

UserName varchar(50),

UserAddress varchar(150))

 

2. Using SELECT...INTO
 

SELECT age as DummField1

Lastname as DummyField2

INTO #myTempTable

FROM DummyTable

 

Now let us see how to insert into temp table;

insert into #LocalTempTable values ( 1, 'Vishal','India');

 

How to select from temp table;

select * from #LocalTempTable

After execution of all these statements, if you close the query window and again execute "Insert" or "Select" Command, it will throw the following error:

But if we choose to close the query window after executing above commands and again execute insert or select command, it will throw an error saying invalid object name #LocalTempTable.

Reason: This is because the scope of Local Temporary table is only bounded with the current connection of current user.

Create Global temp table:

1. Using CREATE

CREATE TABLE ##NewGlobalTempTable(
UserID int,
UserName varchar(50), 
UserAddress varchar(150))

 

2. Using SELECT...INTO
 
SELECT age as DummyField1,
         Lastname as DummyField2
INTO ##myTempTable
FROM DummyTable
 
 

The above script will create a temporary table in tempdb database. We can insert or delete records in the temporary table similar to a general table like:

 

Now let us see how to insert into temp table;

insert into ##NewGlobalTempTable values ( 1, 'Vishal','India');

 

How to select from temp table;

select * from ##NewGlobalTempTable

 

Global temporary tables are visible to all SQL Server connections. When you create one of these, all the users can see it.

When to use Temp tables;

1) When we are doing large number of row manipulation in stored procedure

2) When we have complex join operation.

3) This is useful to replace the cursor. We can store the result set data into a temp table, then we can manipulate the data from there.

 

Deciding between Local and Global


When deciding which type of table to use asks you two questions.

1) "Do I need this data to persist when I am done using it?" If so, I need a standard table, not a temporary table.

2) Do I need the data to be accessed outside of my single process?" This question can sometimes be a little tougher to figure out, so I have a simple suggestion. Make it a local temporary table for now, and if you find out you need a larger scope, change it later.

 

 

 

 Cheers

http://vishalnayan.wordpress.com/


 Subscribe to Articles

     

Further Readings:

Responses

No response found. Be the first to respond this post

Post Comment

You must Sign In To post reply
Find More Articles on C#, ASP.Net, Vb.Net, SQL Server and more Here

Hall of Fame    Twitter   Terms of Service    Privacy Policy    Contact Us    Archives   Tell A Friend