SQL Server临时表 实用大全

我们今天是要和大家一起讨论的是SQL Server临时表的实用大全,如果你对SQL Server临时表的实用大全不是很了解的话,下面的文章就是对其相关内容的具体介绍,希望会给你带来一些帮助在此方面。

引子:

临时数据表格,我们在存储的时候经常遇见。

客户端可以实用Delphi的ClientDataSet的内存表,但是ClientDataSet类似TABLE,不是支持SQL语言的。

当然也可以实用临时表。有时我们避免SQL Server临时表的生命周期的麻烦,更多的使用实际表临时用用。起个什么tempXXX类似的告诉我们他们是临时表。创建释放也没有问题。

那么临时表的周期是什么样子的呢?有什么特殊的用法没有?

1.全局临时表和临时表的区别:视野不同。

全局临时表当然就是使用##打头的表格,普通的临时表格为#打头。它们的周期应该随一个连接也就是Connection的诞生而生,随着Connection的断开而死亡。它们的区别不同的地方也就是视野不同。

全局表,全部授权的Connection都可以看见。但是普通SQL Server临时表(局域临时表)仅仅创建的Connection可以看见。特别说明的是SQL Server的isql.exe每个连接就是一个Connection。

例如:一个应用程序app.exe有仅adoconnection连接SQL Server数据,那么这个连接中的adoquery或者存储过程建立的全局表##temp1,另外的一个app.exe或者其它的appx.exe都可以使用该表格。

不同的是普通临时表,由app.exe中的连接connection比如adoconnection的Adoquery建立的临时表#temp,在所有该连接的该程序的app.exe都可以看见并且访问,但是appx.exe或者其它的就不能看见。

陷阱:如果一个应用程序app.exe有存储过程和TADOQUERY连接同一个ADOCONNECTION.切记使用存储过程建立的临时表(非全局),就不能被这个连接下的TADOQUERY访问。原因是:存储过程本身是服务器端执行,应该是服务器的CONNECTION。

2.全局表或者SQL Server临时表的存储和建立。

估计大家都知道,临时表或者全局表都是在SQL Server的tempdb数据库存储,表我们访问的时候使用#,但是实际在进程里面是以在tempdb里面的用户表以#xxx_________00000000xxx方式存储(是否是进程标识,不大知道,也不想知道)。可以通过isql.exe的tempdb里面看见它们。

3。头痛初始化表格

初始化表格,为什么头痛,毕竟使用Drop什么的。或者判断存在比较麻烦。其实也很简单。另外建立临时表,都是无聊的SQL 语句,怎么处理。

方法一:当然是使用存储过程了。可以直接写SQL语句或者写exec (@v_sql)。

方法二:把SQL Server临时表保存到数据里面MEMO里面,读取,直接执行。

判断方法一:可以采用常用的exists函数。

例如:

  1. if exists (select * from tempdb..sysobjects where id = object_id(@sTmpWareA) and type = "U")

判断方法二:

  1. if object_id(‘tempdb.dbo.##‘[email protected]_userid) is null

应用方法一:(感谢阿满,迷糊)

一个统计的SQL Server临时表格,使用TADOPROC执行存储过程,如下:

  1. CREATE PROCEDURE InitCreateCoawardTable AS
  2. BEGIN
  3. IF not (object_id(‘tempdb.dbo.#Tmp_Detail‘) is null)
  4. drop table tempdb.dbo.#Tmp_Detail
  5. CREATE TABLE tempdb.dbo.#Tmp_Detail (
  6. [id] [int] IDENTITY (1, 1) NOT NULL ,

[单据类别] [varchar] (20) COLLATE Chinese_PRC_CI_AS NULL ,

[单据编号] [varchar] (20) COLLATE Chinese_PRC_CI_AS NULL ,

(。。这里多复杂都可以。。。。。省略。。。)

  1. select * from tempdb.dbo.#Tmp_Detail
  2. END
  3. GO

在客户端使用TADOPROC执行这个存储过程,

  1. with sproc do
  2. begin
  3. try
  4. Close;
  5. ProcedureName:=spName;
  6. Parameters.Refresh;
  7. Prepared;
  8. ExecProc;

Open;//这句不能省略要不,就出现忽略了数据库名称 ‘,将引用 tempdb 中的对象错误。

  1. except
  2. Close;
  3. Exit;
  4. end;
  5. Result:=True;
  6. end;

这样,你的TADOPROC就可以任意使用APPEND,INSERT语句了,更好的是不需要清理,而且方法灵活。更好的有点非常有效的处理并发。当然有些人还在使用建立实际表格代替它,使用会话处理该问题,你还得回收。相当麻烦。而且灵活度差多了。

以下是应用范例转载:

利用SQL Server的全局临时表防止用户重复登录

在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。

可能会有人说在用户信息表中加一字段判断用户工号登录的状态,登录后写1,退出时写0,且登录时判断其标志位是否为1,如是则不让该用户工号登录。但是这样那势必会带来新的问题:如发生象断电之类不可预知的现象,系统是非正常退出,无法将标志位置为0,那么下次以该用户工号登录则不可登入,这该怎么办呢?

或许我们可以换一下思路:有什么东西是在connection断开后可以被系统自动回收的呢?对了,SQL Server的临时表具备这个特性!但是我们这里的这种情况不能用局部临时表,因为局部临时表对于每一个connection来说都是一个独立的对象,因此只能用全局SQL Server临时表来达到我们的目的。

好了,情况已经明朗话了,我们可以写一个象下面这样简单的存储过程:

  1. create procedure gp_findtemptable -- 2001/10/26 21:36 zhuzhichao in nanjing

/* 寻找以操作员工号命名的全局临时表

* 如无则将out参数置为0并创建该表,如有则将out参数置为1

* 在connection断开连接后,全局临时表会被SQL Server自动回收

* 如发生断电之类的意外,全局临时表虽然还存在于tempdb中,但是已经失去活性

* 用object_id函数去判断时会认为其不存在. */

@v_userid varchar(6), -- 操作员工号

@i_out int out -- 输出参数 0:没有登录 1:已经登录

  1. as
  2. declare @v_sql varchar(100)
  3. if object_id(‘tempdb.dbo.##‘[email protected]_userid) is null
  4. begin
  5. set @v_sql = ‘create table ##‘[email protected]_userid+‘(userid varchar(6))‘
  6. exec (@v_sql)
  7. set @i_out = 0
  8. end
  9. else
  10. set @i_out = 1

在这个过程中,我们看到如果以用户工号命名的全局SQL Server临时表不存在时过程会去创建一张并把out参数置为0,如果已经存在则将out参数置为1。

这样,我们在我们的应用程序中调用该过程时,如果取得的out参数为1时,我们可以毫不客气地跳出一个message告诉用户说”对不起,此工号正被使用!”

判断方法范例:

  1. select @sTmpWareA="tempdb..[##MARWareA"+ @ComputerName+"]"
  2. if exists (select * from tempdb..sysobjects where id = object_id(@sTmpWareA) and type = "U")
  3. begin
  4. set @sTmpWareA="[##MARWareA"+ @ComputerName+"]"
  5. exec( "drop table " [email protected] )
  6. end
  7. else
  8. set @sTmpWareA="[##MARWareA"+ @ComputerName+"]"

@sTmpWareA 就是SQL Server临时表的名称,过程中使用exec来操作

From:http://database.51cto.com/art/201007/213431.htm

时间: 2024-11-05 21:53:15

SQL Server临时表 实用大全的相关文章

当 IDENTITY_INSERT 设置为 OFF 时,不能向表 '#TT' 中的标识列插入显式值。 sql server 临时表

当 IDENTITY_INSERT 设置为 OFF 时,不能向表 '#TT' 中的标识列插入显式值.我是在SqlServer写存储过程中遇到的这个错误,当时就心想:临时表怎么会有主键呢,我也没有设置主键.然后我就和同事一块调试,终于发现了.原因就是我把真实的数据表中id(其实就是主键)取出来放到临时表(#TT)中,一开始是以为把主键的属性取出来了.后来又一起调试,发现不是那么回事,1.原来SqlServer会自动给临时表设置主键,如果你要插入数据的话,还要打开主键,这样你才能插入数据.“当 ID

SQL SERVER 临时表导致存储过程重编译(recompile)的一些探讨

SQLSERVER为了确保返回正确的值,或者处于性能上的顾虑,有意不重用缓存在内存里的执行计划,而重新编译执行计划的这种行为,被称为重编译(recompile).那么引发存储过程重编译的条件有哪一些呢?下面罗列了一些导致重编译(recompile)的条件:     - 对查询所引用的表或视图进行更改(ALTER TABLE 和 ALTER VIEW).     - 对执行计划所使用的任何索引进行更改.     - 对执行计划所使用的统计信息进行更新,这些更新可能是从语句(如 UPDATE STA

SQL server 临时表

创建临时表,#代表局部临时表,##代表全局临时表.局部临时表和全局临时表的具体含义是什么呢? 举例说明一下比较清晰些,先来看下局部临时表,[新建查询],在里面输入如下文本: 运行后,我们在此文件执行输入: select * from #tempTable, 执行后可以查询出如下的数据: 我们另外打开一个[新建查询],就给其命名为新建查询2,在新建查询2中执行输入: select * from #tempTable,提示如下:   修改Sql 语句中的#tempTable 为 ##tempTabl

SQL Server 临时表 Vs 表变量

开始 说临时表和表变量,这是一个古老的话题,我们在网上也找到很多的资料阐述两者的特征,优点与缺点.这里我们在SQL Server 2005\SQL Server 2008版本上通过举例子,说明临时表和表变量两者的一些特征,让我们对临时表和表变量有进一步的认识.在本章中,我们将从下面几个方面去进行描述,对其中的一些特征举例子说明: 约束(Constraint) 索引(Index) I/0开销 作用域(scope) 存儲位置 其他 例子描述 约束(Constraint) 在临时表和表变量,都可以创建

SQL SERVER 临时表的排序问题

在SQL SERVER 2005/2008中,如果将有序的记录插入临时表,则从临时表查询出来的记录是有序的(不依赖ORDER BY也是有序状态),但是从SQL SERVER 2012开始,即使插入的记录集有序,查询出来的结果变成无序了.需要依赖ORDER BY来或得到一个有序结果.例如下面例子: SELECT * INTO #tables FROM sys.tables ORDER BY name;   SELECT * FROM #tables; 如上所示,SQL SERVER 2014则是无

SQL SERVER临时表的使用

drop table #Tmp   --删除临时表#Tmpcreate table #Tmp --创建临时表#Tmp(    ID   int IDENTITY (1,1)     not null, --创建列ID,并且每次新增一条记录就会加1    WokNo                varchar(50),       primary key (ID)      --定义ID为临时表#Tmp的主键      );Select * from #Tmp    --查询临时表的数据trun

小记sql server临时表与表变量的区别

临时表与表变量都可以起到“临时”的作用,那么两者主要的区别是什么呢? 这里不讨论创建方式,以及全局临时表.会话临时表这些,主要记录一下个人对两者的主要区别以及适用情况的看法,有什么不对或补充的地方,欢迎讨论. 区别: 1. 表变量存储在内存中,当创建表变量时,sql server不会产生日志,也不会维护统计信息:表变量的字段不能建立索引:不能有约束和默认值.sql server 认为表变量通常只有很少量的数据. 2. 当创建临时表时,sql server会产生日志,统计信息:临时表的字段可以建立

sql server系统存储过程大全

关键词:sql server系统存储过程,mssql系统存储过程 xp_cmdshell --*执行DOS各种命令,结果以文本行返回. xp_fixeddrives --*查询各磁盘/分区可用空间 xp_loginconfig --*报告SQL Server 实例在Windows 上运行时的登录安全配置 xp_logininfo --*返回有关Windows 认证登录的信息. xp_msver --*返回有关Microsoft SQL Server 的版本信息 xp_enumgroups    

Sql Server 日期转换大全

本博文转载,原博文:http://blog.csdn.net/baiduandxunlei/article/details/9180075 CONVERT(data_type,expression[,style])  convert(varchar(10),字段名,转换格式) 说明: 此样式一般在时间类型(datetime,smalldatetime)与字符串类型(nchar,nvarchar,char,varchar) 相互转换的时候才用到. 语句 结果 SELECT CONVERT(varc