zoukankan      html  css  js  c++  java
  • SQLServer temporary table and table variable

    Temporary tables are created in tempdb.  The name "temporary" is slightly misleading, for even though the tables are instantiated in tempdb and backed by physical disk and are even logged into the transaction log.  They act like regular tables in that you can query their data via SELECT queries and modify their data via UPDATE, INSERT, and DELETE statements.  If created inside a stored procedure they are destroyed upon completion of the stored procedure.  Furthermore, the scope of any particular temporary table is the session in which it is created; meaning it is only visible to the current user.  Multiple users could create a temp table named #TableX and any queries run simultaneously would not affect one another - they would remain autonomous transactions and the tables would remain autonomous objects.  You may notice that my sample temporary table name started with a "#" sign.  This is the identifier for SQL Server that it is dealing with a temporary table.

    There are two types temporary table. One is session scope, another one is global scope.

    1. Session scope temporary table

    the identifier of a session scope temporary table must be start with '#', below is an example.Sesson scope temporary table can have clustered and nonclutered index.It only visiable to current session, mutiple session will have a differenttamporary table instance. It will auto destoryed at the end of the session. If it defined in a procedure, then it will be destoryed at the end of the procedure.

    create table #table1(
    
                                   column1 int primary key,
    
                                   column2 int,
    
                                   column3 int,
    
                                   column4 int
    
                                  );
    
    create noclustered index idx_table1_column2 on #table1(column2);

    2. Global scope temporary table

    the identifier of a global scope temporary table must be start with '##', below is an example.

    Global scope temporary table can have clustered and nonclutered index.It is visiable to all the session,

    it will be destroyed when restart SQLServer.

    create table ##table2(
    
                                   column1 int primary key,
    
                                   column2 int,
    
                                   column3 int,
    
                                   column4 int
    
                                  );

    create noclustered index idx_table2_column2 on ##table2 (column2);

    3. Table variable in T-SQL

    In a procedue we can have a table variable, below is a example for how to create it. The table variable can have single column primary key or composit primary key of several columns. We can have clustered index on the primary key, but we can have nonclusted index.Below are two example about how to define table variable.

    declare @table3  table (
    
                                   column1 int primary key,
    
                                   column2 int,
    
                                   column3 int,
    
                                   column4 int
    
                                   );
    declare @table4  table (
    
                                   column1 int,
    
                                   column2 int,
    
                                   column3 int,
    
                                   column4 int
    
                                   primary key(column1,column2)
    
                                   );

    The table variable exactly is also instantiated in the tempdb. Some one thought it was a memory table,but that's not true. 

    Below is an experiment to show it is stored in tempdb.

    /* Check the difference between Temp Table and Memory Tables */
    -- Get Current Session ID
    SELECT @@SPID AS Current_SessionID
    -- Check the space usage in page files
    SELECT user_objects_alloc_page_count
    FROM sys.dm_db_session_space_usage
    WHERE session_id = (SELECT @@SPID )
    GO
    -- Create Temp Table and insert three thousand rows
    CREATE TABLE #TempTable (Col1 INT)
    INSERT INTO #TempTable (Col1)
    SELECT TOP 3000 ROW_NUMBER() OVER(ORDER BY a.name)
    FROM sys.all_objects a
    CROSS JOIN sys.all_objects b
    GO
    -- Check the space usage in page files
    SELECT user_objects_alloc_page_count
    FROM sys.dm_db_session_space_usage
    WHERE session_id = (SELECT @@SPID )
    GO
    -- Create Table Variable and insert three thousand rows
    DECLARE @temp TABLE(Col1 INT)
    INSERT INTO @temp (Col1)
    SELECT TOP 3000 ROW_NUMBER() OVER(ORDER BY a.name)
    FROM sys.all_objects a
    CROSS JOIN sys.all_objects b
    GO
    -- Check the space usage in page files
    SELECT user_objects_alloc_page_count
    FROM sys.dm_db_session_space_usage
    WHERE session_id = (SELECT @@SPID )
    GO
    -- Clean up
    DROP TABLE #TempTable
    GO

    Temporary table:

    • Table variables can have Clustered and Non-Clustered Indexes
    • You can have constraints 
    • You can create default values on columns
    • Statistics can be created against table variables

    Table variable have certain clear limitations: 

    • Table variables can not have Non-Clustered Indexes,but it can have clustered index
    • You can not create constraints in table variables
    • You can not create default values on table variable columns
    • Statistics can not be created against table variables

    Common for temporary table and table variable

    • Instantiated in tempdb
    • Clustered indexes can be created on table variables and temporary tables
    • Both are logged in the transaction log
    • Just as with temp and regular tables, users can perform all Data Modification Language (DML) queries against a table variable:  SELECT, INSERT, UPDATE, and DELETE.
  • 相关阅读:
    js实现完美身份证号有效性验证
    jQuery cookie操作
    脚本化HTTP
    if (HttpContext.Current.User.Identity.IsAuthenticated) 权限验证总是true
    装了appserv之后,浏览器中访问localhost加载不了
    rdlc报表的导出及预览时表头
    oracle中的to_number在mysql中的转换
    GIRDVIEW 控件绑定数据后 后台c#控制隐藏某列
    mysql、oracle 中按照拼音首字母排序
    阅读《大道至简第一章》读后感(java伪代码)
  • 原文地址:https://www.cnblogs.com/princessd8251/p/3671414.html
Copyright © 2011-2022 走看看