Sql Server临时表和游标的使用小结

2020-07-06 05:57:49易采站长站整理

判断存在性:


if CURSOR_STATUS('global','游标名称') =-3 and CURSOR_STATUS('local','游标名称') =-3
begin
print 'not exists'
end
SELECT * FROM [tempdb].[dbo].[sysobjects] where xtype='u'

判断临时表的存在性:


if object_id('tempdb..#tem') is not null
begin
print 'exists'
end
else
begin
print 'not exists'
end

特别提示:
1。在动态sql语句中创建的局部临时表,在语句运行完毕后就自动删除了
所以下面的语句是得不到结果集的


exec('select * into #tems from jobs')
select * from #tems

2。在存储过程中用到的临时表在过程运行完毕后会自动删除
但是推荐显式删除,这样有利于系统

ii。游标
游标也有局部和全局两种类型
局部游标:只在声明阶段使用
全局游标:可以在声明它们的过程,触发器外部使用

判断存在性:


if CURSOR_STATUS('global','游标名称') =-3 and CURSOR_STATUS('local','游标名称') =-3
begin
print 'not exists'
end

您可能感兴趣的文章:SQL Server查看未释放游标的方法SQL Server使用游标处理Tempdb究极竞争-DBA问题-程序员必知MS SQL Server游标(CURSOR)的学习使用sqlserver游标使用步骤示例(创建游标 关闭游标)SQLServer用t-sql命令批量删除数据库中指定表(游标循环删除)SQL Server 游标语句 声明/打开/循环实例SQL Server游标的使用/关闭/释放/优化小结SQL Server遍历表中记录的2种方法(使用表变量和游标)sqlserver中触发器+游标操作实现SQL Server游标的介绍与使用

相关文章 大家在看