Now we will see about, how SQL server 2014 can cache temp tables. Before we move further into the subject, will see about temp tables in crisp. These are the tables created at the run time and these tables are created within the “tempdb” database. To identify a table as a Temporary Table within the SQL statement, prefix the table name with the “#” character. And also we should know one more fact the caching is not per procedure , the caching is per objects.
SQL Server 2014 has given us some room, by which if we make our temp table in a proper way the temp table can be cached. We will see how this is possible.
CREATE PROCEDURE TempTableCaching |
CREATE UNIQUE CLUSTERED INDEX idx_c1 ON #TempTable(Col1) |
INSERT INTO #TempTable VALUES ( 'Hi' , 'Test data' ) |
Now by the code you are creating DDL statement through the (CREATE UNIQUE CLUSTERED INdex , we )have mixed the DDL Statement with DML statement. Because of this reason SQL Server was not able to Cache the temp table.
To prove, how many times the temp tables are created we will make of use of the dmv sys.dm_os_performance_counters. Just execute the below code and scroll down to the last to check how many times the temp table was created.
DECLARE @table_counter_before_test BIGINT ; |
SELECT @table_counter_before_test = cntr_value FROM sys.dm_os_performance_counters |
WHERE counter_name = 'Temp Tables Creation Rate' |
DECLARE @table_counter_after_test BIGINT ; |
SELECT @table_counter_after_test = cntr_value FROM sys.dm_os_performance_counters |
WHERE counter_name = 'Temp Tables Creation Rate' |
PRINT 'Temp tables created during the test: ' + CONVERT ( VARCHAR (100), @table_counter_after_test - @table_counter_before_test) |
You will find the below message the temp tables where created
(1 row(s) affected)
Temp tables created during the test: 1000
Now we will see how we can make the procedure in a perfect way, by which SQL Server can cache tthe temp tables.
ALTER PROCEDURE TempTableCaching |
Col1 INT IDENTITY(1, 1) PRIMARY KEY , |
Col2 CHAR (100) INDEX idx_Col2, |
Col3 CHAR (100) INDEX idx_Col3 |
INSERT INTO #TempTable VALUES ( 'Hi' , 'Test data' ) |
Now by the above code we have created the indexes, while we create the table itself. Hence we are not mixing the DDL and DML. Just go back and rerun the code, which checks how many times the temp table was created.
(1 row(s) affected)
Temp tables created during the test: 1
Yes the table was created just once. As a conclusion this also means that SQL Server is not able to cache Temp Tables when you create additional Non-Clustered Indexes, because you are then again mixing DDL with DML statements within your Stored Procedure.
But with SQL Server 2014 you can overcome this limitation, because you are now able to create indexes inline within your CREATE TABLE statement
No comments:
Post a Comment