zoukankan      html  css  js  c++  java
  • sql中临时表的创建和使用【本文转自多人博客】

    本模块原网址:http://www.cnblogs.com/jeffwongishandsome/archive/2009/08/05/1526466.html

    原作者:Jeff Wong

    1、创建方法:
    方法一:
    create table TempTableName

    select [字段1,字段2,...,] into TempTableName from table 
    方法二:
    create table tempdb.MyTempTable(Tid int)
    说明:
    (1)、临时表其实是放在数据库tempdb里的一个用户表;
    (2)、TempTableName必须带“#”,“#"可以是一个或者两个,以#(局部)或##(全局)开头的表,这种表在会话期间存在,会话结束则自动删除;
    (3)、如果创建时不以#或##开头,而用tempdb.TempTable来命名它,则该表可在数据库重启前一直存在。
    2、手动删除
    drop table TempTableName
    说明:

     DROP  TABLE 语句显式除去临时表,否则临时表将在退出其作用域时由系统自动除去:     
    (1)、当存储过程完成时,将自动除去在存储过程中创建的本地临时表。由创建表的存储过程执行的所有嵌套存储过程都可以引用此表。但调用创建此表的存储过程的进程无法引用此表;
    (2)、所有其它本地临时表在当前会话结束时自动除去;
    (3)、全局临时表在创建此表的会话结束且其它任务停止对其引用时自动除去。任务与表之间的关联只在单个Transact-SQL语句的生存周期内保持。换言之,当创建全局临时表的会话结束时,最后一条引用此表的Transact-SQL语句完成后,将自动除去此表。
    3、示例代码

    CREATE TABLE #temp1 --创建临时表
    	(
    	 ID INT IDENTITY(1,1),--主键ID,并且自增1
    	 CPU VARCHAR(100) ,
    	 PRIMARY KEY(ID)--ID为主键
    	)
    	INSERT INTO #temp1 (CPU) VALUES ('AMD') --往临时表了里面插入数据-第一种
    	INSERT INTO #temp1 SELECT *FROM MyTAble  --批量插入数据
    	SELECT * FROM #temp1  --查询临时表的数据
    	TRUNCATE  TABLE  #temp1  --清除临时表的数据
    
    	--创建局部临时表--方法二
    	SELECT * INTO #temp2 FROM  Citys
    	SELECT * FROM  #temp2
    
    	
    	--创建临时表  --方法三
    	create table tempdb.MyTempTable(ID int) --有对应权限才可以这么写
    

      --示例  来源于:http://blog.csdn.net/lsgis2001/article/details/8709849

    DECLARE @startTime VARCHAR(10)='2014-08-08',@endTime VARCHAR(10)='2014-09-09',@count INT=1
    --创建临时表
    CREATE TABLE #Temp
    (
     T_Date VARCHAR(10)
    )
    WHILE CONVERT(VARCHAR(7),DATEADD(m,@count,@startTime),120)<=CONVERT(VARCHAR(7),@endTime,120)
    BEGIN
     INSERT INTO #Temp (T_Date)
     VALUES  (CONVERT(VARCHAR(10),DATEADD(m,@count,@startTime),120)
     SET @count=@count+1
    END
    	 
    

      

  • 相关阅读:
    推荐前端开发使用的服务器环境开源项目 D2Server 可替代Apache
    JavaScript正则表达式的坑很深
    NodeJS + Sequelize + Mysql + Vue + Bootstrap
    wampserver使用过程中遇到的问题及相关配置
    生成解决方案时,无法导入以下密钥文件
    使用Image.GetThumbnailImage 方法返回缩略图
    C#操作xml文件进行增、删、改
    MessageBox.Show()时MessageBoxIcon的显示
    通过反射获取对象属性、属性的值,设置对象属性的值
    常用文档处理技巧
  • 原文地址:https://www.cnblogs.com/alphafly/p/3957439.html
Copyright © 2011-2022 走看看