• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Sql Server临时表和游标的使用小结

    1.临时表

    临时表与永久表相似,但临时表存储在 tempdb 中,当不再使用时会自动删除。
    临时表有局部和全局两种类型

    2者比较:

    局部临时表的名称以符号 (#) 打头
    仅对当前的用户连接是可见的
    当用户实例断开连接时被自动删除
    全局临时表的名称以符号 (##) 打头
    任何用户都是可见的
    当所有引用该表的用户断开连接时被自动删除
    实际上局部临时表在tempdb中是有唯一名称的
    例如我们用sa登陆一个查询分析器,再用sa登陆另一查询分析器

    在2个查询分析器我们都允许下面的语句:

    use pubs
    go
    select * into #tem from jobs

    分别为2个用户创建了2个局部临时表
    我们可以从下面的查询语句可以看到

    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
    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
    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游标的介绍与使用
    上一篇:SQLServer中使用扩展事件获取Session级别的等待信息及SQLServer 2016中Session级别等待信息的增强
    下一篇:SQL查询方法精华集
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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