Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 506|回复: 0

[默认分类] sqlserver创建临时表 【转】

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-7-7 12:40:19 | 显示全部楼层 |阅读模式
    创建临时表
           方法一:
         create table #临时表名(字段1 约束条件,
                          字段2 约束条件,
                      .....)
            create table ##临时表名(字段1 约束条件,
                              字段2 约束条件,
                          .....)
            方法二:
         select * into #临时表名 from 你的表;
           select * into ##临时表名 from 你的表;
    注:以上的#代表局部临时表,##代表全局临时表

    查询临时表
         select * from #临时表名;
           select * from ##临时表名;

    删除临时表
         drop table #临时表名;
           drop table ##临时表名;




    SQL SERVER临时表的使用


    http://www.cnblogs.com/shineqiujuan/arcHive/2008/11/13/1332657.HTML




      
       
       
         drop table #Tmp   --删除临时表#Tmp
    create table #Tmp --创建临时表#Tmp
    (
        ID   int IDENTITY (1,1)     not null, --创建列ID,并且每次新增一条记录就会加1
        WokNo                varchar(50),   
        primary key (ID)      --定义ID为临时表#Tmp的主键      
    );
    Select * from #Tmp    --查询临时表的数据
    truncate table #Tmp --清空临时表的所有数据和约束
         相关例子:
         Declare @Wokno Varchar(500) --用来记录职工号
    Declare @Str NVarchar(4000) --用来存放查询语句
    Declare @Count int --求出总记录数      
    Declare @i int
    Set @i = 0
    Select @Count = Count(Distinct(Wokno)) from #Tmp
    While @i < @Count
        Begin
           Set @Str = "Select top 1 @Wokno = WokNo from #Tmp Where id not in (Select top " + Str(@i) + "id from #Tmp)"
           Exec Sp_ExecuteSql @Str,N"@WokNo Varchar(500) OutPut",@WokNo Output
           Select @WokNo,@i --一行一行把职工号显示出来
           Set @i = @i + 1
        End
         
    临时表
    可以创建本地和全局临时表。本地临时表仅在当前会话中可见;全局临时表在所有会话中都可见。
    本地临时表的名称前面有一个编号符 (#table_name),而全局临时表的名称前面有两个编号符 (##table_name)。
         SQL 语句使用 CREATE TABLE 语句中为 table_name 指定的名称引用临时表:
         CREATE TABLE #MyTempTable (cola INT PRIMARY KEY)
    INSERT INTO #MyTempTable VALUES (1)
         如果本地临时表由存储过程创建或由多个用户同时执行的应用程序创建,则 SQL Server 必须能够区分由不同用户创建的表。为此,SQL Server 在内部为每个本地临时表的表名追加一个数字后缀。存储在 tempdb 数据库的 sysobjects 表中的临时表,其全名由 CREATE TABLE 语句中指定的表名和系统生成的数字后缀组成。为了允许追加后缀,为本地临时表指定的表名 table_name 不能超过 116 个字符。
         除非使用 DROP TABLE 语句显式除去临时表,否则临时表将在退出其作用域时由系统自动除去:
         当存储过程完成时,将自动除去在存储过程中创建的本地临时表。由创建表的存储过程执行的所有嵌套存储过程都可以引用此表。但调用创建此表的存储过程的进程无法引用此表。
         
    所有其它本地临时表在当前会话结束时自动除去。
         
    全局临时表在创建此表的会话结束且其它任务停止对其引用时自动除去。任务与表之间的关联只在单个 Transact-SQL 语句的生存周期内保持。换言之,当创建全局临时表的会话结束时,最后一条引用此表的 Transact-SQL 语句完成后,将自动除去此表。
    在存储过程或触发器中创建的本地临时表与在调用存储过程或触发器之前创建的同名临时表不同。如果查询引用临时表,而同时有两个同名的临时表,则不定义针对哪个表解析该查询。嵌套存储过程同样可以创建与调用它的存储过程所创建的临时表同名的临时表。嵌套存储过程中对表名的所有引用都被解释为是针对该嵌套过程所创建的表,例如:
         CREATE PROCEDURE Test2
    AS
    CREATE TABLE #t(x INT PRIMARY KEY)
    INSERT INTO #t VALUES (2)
    SELECT Test2Col = x FROM #t
    GO
    CREATE PROCEDURE Test1
    AS
    CREATE TABLE #t(x INT PRIMARY KEY)
    INSERT INTO #t VALUES (1)
    SELECT Test1Col = x FROM #t
    EXEC Test2
    GO
    CREATE TABLE #t(x INT PRIMARY KEY)
    INSERT INTO #t VALUES (99)
    GO
    EXEC Test1
    GO
         下面是结果集:
         (1 row(s) affected)
         Test1Col   
    -----------
    1         
         (1 row(s) affected)
         Test2Col   
    -----------
    2         
         当创建本地或全局临时表时,CREATE TABLE 语法支持除 FOREIGN KEY 约束以外的其它所有约束定义。如果在临时表中指定 FOREIGN KEY 约束,该语句将返回警告信息,指出此约束已被忽略,表仍会创建,但不具有 FOREIGN KEY 约束。在 FOREIGN KEY 约束中不能引用临时表。
         考虑使用表变量而不使用临时表。当需要在临时表上显式地创建索引时,或多个存储过程或函数需要使用表值时,临时表很有用。通常,表变量提供更有效的查询处理。
       
      




    转至:http://www.cnblogs.com/Hdsome/archive/2008/12/10/1351504.html
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-24 01:33 , Processed in 0.418873 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表