社区
疑难问题
帖子详情
SQL SERVER 中的全局临时表问题
luozhengeast
2003-09-10 01:47:52
请问高人:我在 SQL SERVER 中写了一个建立全局临时表的存储过程,然后用VB 通过ADO调用,但是却发现有时能建立(在数据库tempdb中的sysobjects 表中能看到临时表),有时又不能建立,请问这是啥原因,全局临时表在什麽情况下会自动删除?
有啥办法能控制全局临时表的自动删除吗?
...全文
112
2
打赏
收藏
SQL SERVER 中的全局临时表问题
请问高人:我在 SQL SERVER 中写了一个建立全局临时表的存储过程,然后用VB 通过ADO调用,但是却发现有时能建立(在数据库tempdb中的sysobjects 表中能看到临时表),有时又不能建立,请问这是啥原因,全局临时表在什麽情况下会自动删除? 有啥办法能控制全局临时表的自动删除吗?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
2 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
lionstar
2003-09-10
打赏
举报
回复
你可以将创建全局临时表的存储过程创建完毕后使用waitfor(xxxxxxxxx)数字越大,持续时间越长,然后存储过程设置成SQL Server启动时自动运行的:
sp_procoption [ @ProcName = ] 'procedure'
, [ @OptionName = ] 'option'
, [ @OptionValue = ] 'value'
参数
[@ProcName =] 'procedure'
是要为其设置或查看选项的过程名。procedure 为 nvarchar(776) 类型,无默认值。
[@OptionName =] 'option'
要设置的选项的名称。option 的唯一值是 startup,该值设置存储过程的自动执行状态。设置为自动执行的存储过程会在每次 Microsoft® SQL Server™ 启动时运行。
[ , [ @OptionValue = ] 'value' ]
表示选项是设置为开(true 或 on)还是关(false 或 off)。value 为 varchar(12) 类型,无默认值。
liuyun2003
2003-09-10
打赏
举报
回复
有本地和全局两种类型的临时表,二者在名称、可见性和可用性上均不相同。本地临时表的名称以单个数字符号 (#) 打头;它们仅对当前的用户连接是可见的;当用户从 Microsoft® SQL Server™ 2000 实例断开连接时被删除。全局临时表的名称以数学符号 (##) 打头,创建后对任何用户都是可见的,当所有引用该表的用户从 SQL Server 断开连接时被删除。
Microsoft
SQL
Server
2005技术内幕: T-SQ程序设计.pdf
SQL
Server
2005微软官方权威参考手册 是Inside Microsoft
SQL
Server
2005系列书
中
的第一本,
SQL
Server
类的顶尖之作 全球公认
SQL
Server
2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。 本系列图书
中
文版得到了微软总部
SQL
Server
组专家的高度重视,同时也得到了微软
中
国上海
SQL
Server
全球技术支持
中
心的高度关注。 本书详细介绍了T-
SQL
的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书
中
的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的
问题
。本书涵盖了T-
SQL
程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-
SQL
和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户、使用Service Broker来控制数据库应用程序
中
的异步处理等。 内容简介 本书是Inside Microsoft
SQL
Server
2005系列四本著作
中
的一本。它详细介绍了T-
SQL
的内部构造,包含了非常全面的编程参考。它提供了使用Transact-
SQL
(T-
SQL
)的专家级指导,T-
SQL
是用于
SQL
Server
的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被
SQL
Server
引擎解释和处理。 通过本书,你将深入了解T-
SQL
的高级用法,包括触发器、用户自定义函数、异常处理等。该书解释并比较了
SQL
Server
2000和
SQL
Server
2005在数据库开发相关
问题
上的解决方案,深入讨论了
SQL
Server
2005
中
新增的T-
SQL
编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-
SQL
。 本书适合于专业数据库开发者、BI开发者、DBA和以
SQL
Server
作为后台数据库的一般应用程序开发者,读者可以通过书
中
的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际
问题
。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft
SQL
Server
MVP(最有价值专家),并在全世界已经开展过无数次T-
SQL
查询、T-
SQL
优化和编程方面的培训。Itzik是Microsoft
SQL
Server
方面几本著作的作者。他在
SQL
Server
Magazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种
SQL
用户组、PASS、
SQL
server
Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要求、修复
问题
、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-
SQL
查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列
SQL
Server
和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的
问题
,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理 Datetime相关的查询
问题
1.2 与字符相关的
问题
模式匹配 区分大小写(Case-Sensitive)的筛选器 1.3 大型对象(Large Object,LOB) MAX 说明符 BULK行集提供程序 1.4 隐式转换(Implicit Conversion) 标量表达式 筛选表达式 1.5 基于CLR的用户定义类型 UDT理论简介 开发UDT 1.6 XML数据类型 关系数据库
中
的XML支持 什么时候应该使用XML代替关系表现形式? 数据库
中
的XML序列化对象 使用开放架构(Open Schema)的XML 作为存储过程参数的XML数据类型 Xquery修改语句 1.7 结论 第2章
临时表
和表变量 2.1
临时表
局部
临时表
全局
临时表
2.2 表变量 限制条件 tempdb 范围和可见性 事务上下文 统计信息 2.3 tempdb相关的注意事项 2.4 表表达式 2.5 比较临时对象 2.6 综合练习——关系分区(Relational Division) 2.7 结论 第3章 游标 3.1 使用游标 3.2 游标开销 3.3 单独处理每一行 3.4 按顺序访问 自定义聚合 连续聚合 最大并发会话 匹配
问题
3.5 结论 第4章 动态
SQL
第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章 触发器 第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库:
SQL
Server
A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和
SQL
Server
索引
中
英文术语对照表
sql
server
创建
全局
临时表
1)情况:
sql
server
创建
全局
临时表
,即不同的会话都能访问到的
临时表
,但是会话断开后,
临时表
会自动消失,注意:如果存在并发的情况,就不用这个
全局
临时表
了,本人就遇过一个BUG(以前大佬留下的坑,根本复现不了,我也找了好久,鹅丢),并发产生的数据覆盖
问题
,而且发生概率极低。。。 2)环境: 数据库:
sql
server
2008 3)
SQL
:创建
全局
临时表
--若是已存在,删除 if object_id('tempdb..##table') is not null dr.
在
SQL
Server
中
创建
全局
临时表
的技巧
全局
临时表
是一种在
SQL
Server
数据库
中
创建的
临时表
,它可以在不同的会话之间共享数据。与普通的
临时表
不同,
全局
临时表
的作用范围跨越多个会话,使得多个会话可以共享相同的
临时表
数据。然后,在会话2
中
,我们可以直接从
全局
临时表
中
检索数据,即使这两个会话是在不同的数据库连接上下文
中
执行的。在这个示例
中
,我们创建了一个名为"Employee"的
全局
临时表
,该表有三个列:EmployeeID、FirstName和LastName。一旦创建了
全局
临时表
,它将在数据库
中
存在,直到创建它的会话结束或者显示地删除它。
SQL
Server
中
本地
临时表
和
全局
临时表
的区别
在
SQL
Server
中
,
临时表
有两种类型,分别为本地
临时表
和
全局
临时表
。
临时表
和永久表相似,但
临时表
存储在数据库tempdb
中
,当不再使用时回自动删除。 区别 作用域不同 本地
临时表
只对创建这个表的用户的SESSION可见,对其他进程是不可见的。当创建它的进程消失时,这个
临时表
就会自动删除。
全局
临时表
对整个
SQL
Server
示例都可见,只有当所有访问它的SESSION都消失的时候,它才会自动删除。 创建方式不同 本地
临时表
的名称是以单#打头,而
全局
临时表
的名称是以双#打头,如它们的创建语句如下: .
【转】
Sql
server
中
临时表
和
全局
临时表
SQL
Server
支持
临时表
。
临时表
就是那些名称以井号 (#) 开头的表。如果当用户断开连接时没有除去
临时表
,
SQL
Server
将自动除去
临时表
。
临时表
不存储在当前数据库内,而是存储在系统数据库 tempdb 内。
临时表
有两种类型: 本地
临时表
以一个井号 (#) 开头的那些表名。只有在创建本地
临时表
的连接上才能看到这些表。
全局
临时表
以两个井号 (##) 开头的那些表名。在所有连接上都能看到
全局
临时表
。如果在创建
全局
临时表
的连接断开前没有显式地除去这些表,那么只要所有其它任务停止引用它们
疑难问题
22,297
社区成员
121,730
社区内容
发帖
与我相关
我的任务
疑难问题
MS-SQL Server 疑难问题
复制链接
扫一扫
分享
社区描述
MS-SQL Server 疑难问题
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章