关闭

SQL中系统临时表的使用和禁忌 及 Exec(SQLScript) 的使用

223人阅读 评论(0) 收藏 举报
分类:
以前在SQL 中写SP 时,如比较复杂时,喜欢中间使用临时表来暂存相关记录,这样的好处有很多,提高效率,提高程序的可读性等。当然后临时表的使用,一般均会使用用户临时表,即 #TempTable, 但有一些情况下,偶尔也会使用系统临时表,即 ##TempTable。 

两种临时表的的使用语法差不多,可用几种方法来建立,可 Create ,也可 Select Into 。 

当然关键的是系统临时表和用户临时表的区别:(如下) 
1)用户临时表:用户临时表的名称以单个数字符号(#)开头; 
用户临时表只对创建这个表的用户的Session可见,对其他进程是不可见的. 
当创建它的进程消失时这个临时表就自动删除. 
2)系统临时表:系统临时表的名称以数字符号(##)开头 
全局临时表对整个SQL Server实例都可见,但是所有访问它的Session都消失的时候,它也自动删除. 



明白了这些就知道了他们的用途和限制,但有一些地方还是容易出问题,故在此专门列出。 



1, 在使用 Exec(SQLScript) 执行Script 时,其间也相当于单独有一个进程处理,故执行期间内如果创建用户临时表的话,在执行完成后也就结束了,即执行完成后,你不可以使用在 SQLScript 中生成的用户临时表,可以用系统临时表代替。 

2, 在使用用户临时表时,有一个问题要注意,就是最好在建立时指定其用户为 dbo ,以避免可能的问题; 

3, 在使用系统临时表时,一定要考虑到,不可以将其用于多用户使用的环境功能或系统中,否则就可能出现冲突的问题,导致结果不可预料。 



如果在多用户使用的环境中使用系统临时表,则可能会出现多个用户同时对同一系统临时表进行处理,从而导致冲突和数据的错误。以前没有注意这一点,我就因此而浪费过不少的时间。 



有时需要使用Exec(SQLScript)方式产生数据,但其中只能使用系统临时表,如何处理呢? 

1, 可以预先定义好一个用户临时表,然后使用 Insert #TempTable Exec(SQLScript) 的方式,即可将Exec 产生的结果记录加入用户临时表,从而避免使用系统临时表; 

2, 从根本上避免使用 Exec() ,可用其它方式代替。 



Exec() 的使用是因为有一些 Script 比较复杂,其中需要一些组合字符,如 in ('','','') 或其它可能的情况,在此情况,无法直接使用一般的Script 产生记录,只能先产生一个组合的Script ,然后用Exec 执行。
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

禁忌搜索算法(现代优化计算方法)

1.局部搜索算法 a.定义 step1:选定一个初始可行解:x0;记录当前最优解:xbest=x0,T=N(xbest)。 step2:当T \ ( xbest ) = 空集时,或者满足...
  • ChinaJane163
  • ChinaJane163
  • 2015-10-17 15:14
  • 6314

实现将存储过程作为inser into的数据源,插入临时表

1、引言         今天项目制作报表需要实现一个功能,将执行一个存储过程后的数据表,作为数据源,插入到一张临时表里。由于这个临时表知识系统自动生成的字符串,并没有在数据库(SQL Server...
  • xie_xiansheng
  • xie_xiansheng
  • 2016-10-25 19:15
  • 2288

关于with as 作为查询片段的使用和与临时表#Table的比较

http://bbs.csdn.net/topics/300131856 一.WITH AS的含义     WITH AS短语,也叫做子查询部分(subquery factoring),可以让你...
  • dahaizhiliang
  • dahaizhiliang
  • 2013-05-04 15:49
  • 1272

SQL Server 系统表介绍:sys.dm_exec_sessions

管理视图用法
  • peter82
  • peter82
  • 2015-06-19 09:39
  • 1338

SQL Server 系统表介绍:dm_exec_connections

管理视图
  • peter82
  • peter82
  • 2015-06-19 09:49
  • 467

优化临时表使用,SQL语句性能提升100倍

【问题现象】 线上mysql数据库爆出一个慢查询,DBA观察发现,查询时服务器IO飙升,IO占用率达到100%, 执行时间长达7s左右。 SQL语句如下: SELECT DISTINCT...
  • Before_Morning
  • Before_Morning
  • 2015-07-17 09:47
  • 841

sql 存储过程 临时表和游标的使用

--本问题为解决 两张excel表中有关联的数据 将一张表的某些字段数据 加载到另一个表中 USE [test] GO /****** Object: StoredProcedure [dbo]...
  • qq_27107959
  • qq_27107959
  • 2016-09-29 17:47
  • 98

优化临时表使用,SQL语句性能提升100倍

【问题现象】 线上mysql数据库爆出一个慢查询,DBA观察发现,查询时服务器IO飙升,IO占用率达到100%, 执行时间长达7s左右。 SQL语句如下: SELECT DISTINCT...
  • ak619
  • ak619
  • 2015-08-03 10:30
  • 157

数据库 优化临时表使用,SQL语句性能提升100倍

【问题现象】线上mysql数据库爆出一个慢查询,DBA观察发现,查询时服务器IO飙升,IO占用率达到100%, 执行时间长达7s左右。 SQL语句如下:SELECT DISTINCT g.*, cp...
  • qilixiang012
  • qilixiang012
  • 2015-06-02 23:56
  • 331

MS SQL SERVER 2008 使用OBJECT_ID判断临时表是否存在

我们在写sql 脚本的时候经常会用到临时表,有时间也需要根据临时表是否存在做一些逻辑处理。还好sql server已经集成了一个 Object_ID的函数,能够判断是否创建了临时表。使用挺方便的。 ...
  • dyllove98
  • dyllove98
  • 2013-07-05 22:31
  • 753
    个人资料
    • 访问:91747次
    • 积分:1349
    • 等级:
    • 排名:千里之外
    • 原创:20篇
    • 转载:150篇
    • 译文:0篇
    • 评论:3条
    最新评论