当前位置:  数据库>oracle

深入研究Oracle数据库中的临时表

    来源: 互联网  发布时间:2017-04-28

    本文导语: 最近考虑到我们的数据库端写存储过程关于临时表使用的情况,由于我们现在还不清Oracle楚数据库端到底是怎么处理的?是否和SQL Server的处理方式相同,是否会存在隐患等等一些问题,为了避免将来不必要的麻烦我做了深入的...

最近考虑到我们的数据库端写存储过程关于临时表使用的情况,由于我们现在还不清Oracle楚数据库端到底是怎么处理的?是否和SQL Server的处理方式相同,是否会存在隐患等等一些问题,为了避免将来不必要的麻烦我做了深入的研究和查看了一些权威的资料。

  Oracle临时表是注意一下:

  首先是创建临时表的语法:

  CREATE GLOBAL TEMPORARY TABLE table

  "(" column datatype [DEFAULT expr] [{ NULL | NOT NULL}]

  [, column datatype [DEFAULT expr] [ {NULL | NOT NULL} ]… ")"

  ON COMMIT {DELETE | PRESERVE } ROWS

  Oracle中的临时表有两种一种是事务级别的临时表它在事务结束的时候自动清空记录,另一种是会话级的它在我们访问数据库是的一个会话结束后自动 的清空。关于临时表多用户并行不是问题,一个会话从来不会阻止另一个会话使用临时表。即使“锁定”临时表,一个会话也不会阻止其他会话使用它们的临时表。

  如果有在SQL Server或Sybase中使用临时表的经验,需要主要考虑的不是执行select x,y ,z into #temp from some_table 来创建和装载临时表,而是:

  1.对于每一个数据库,创建所有的temp表作为全局临时表。这将作为应用程序安装的一部分完成,就像创建永久表一样。

  2.只要在过程中简单的insert into temp(x,y,z) selelct x,y,z from some_table。

  只是理解这点,这里的目的不是运行存储过程创建表。在Oracle中这样做不是正确的方法。DDL是一种消耗资源非常大的操作,在运行时尽量不要使 用,应用程序需要的临时表应在应用程序安装时创建,而不是在运行时创建。Oracle中的临时表和其他数据库的临时表是相似的,在每个数据库中创建临时表 一次,不必在数据库中的每个存储过程中创建一次。临时表总是存在的,他们作为对象存在于数据字典中,并且总是保持为空,直到有会话在其中放入数据。

  所有我在这里说明如果我们在存储过程中建临时表,每次都建立一个那么我的系统随着用户的操作调用此存储过程,每次多一个这样的表,我们在不知不觉中 数据库中的表的数量会越来越多,而我们还不知道会存在很大的隐患的所有说这点不可小视,为了我们的系统能在客户那里平稳、安全的运行我们一定要注意这样的 问题。如果不手动Drop 表,临时表还是在数据字典中存在的。


    
 
 

您可能感兴趣的文章:

  • 深入理解Oracle数据库的启动和关闭
  • 深入解析Linux下MySQL数据库的备份与还原
  • 深入分析关于Oracle数据库的备份策略
  • SqlServer系统数据库的作用深入了解
  • 深入探讨:MySQL数据库MyISAM与InnoDB存储引擎的比较
  • 深入数据库通用的连接方式详解
  • 深入理解MySQL的数据库引擎的类型
  • Oracle 9i数据库中动态重配置深入分析
  • 深入SQL Server 跨数据库查询的详解
  • 深入探讨:oracle中方案的概念以及方案与数据库的关系
  • 深入分析C#连接Oracle数据库的连接字符串详解
  • 深入分析MSSQL数据库中事务隔离级别和锁机制
  • MySQL数据库引擎介绍、区别、创建和性能测试的深入分析
  • 深入解析C语言中常数的数据类型
  • 深入理解Activity之间的数据传递
  • 深入sql数据连接时的一些问题分析
  • 深入了解mysql的4种常用、重要的数据类型
  • 深入同步访问共享的可变数据分析
  • mysql整数数据类型深入解析
  • 深入理解c# static 静态数据成员和方法
  • 可视化Swing中JTable控件绑定SQL数据源的两种方法深入解析
  • Oracle数据块实现原理深入解读
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Docker支持更深入的容器日志分析
  • 关于《深入浅出MFC》
  • Linux有没有什么好的高级的书,我要深入,
  • 深入理解linux内核
  • [100分]有没有关于binutils的深入的资料?或者深入底层的资料?
  • Web服务器/前端 iis7站长之家
  • 想深入学习Java应该学习哪些东西
  • 哪位有《JSP深入编程》电子版?
  • 想要深入学习LINUX该学什么?
  • 100分求:哪儿有《深入理解linux内核》可供下哉!
  • 如何深入Linux的内核学习?
  • U-BOOT得掌握到什么程序,用不用深入去学
  • 想深入了解操作系统该怎么做
  • 前一阵子学习了shell脚本,如果想深入点了解linux可以看什么书呢
  • 问一个《深入理解计算机系统》中的问题
  • 深入多线程之:深入分析Interlocked
  • ##想买书深入学习linux下的编程,请指教
  • 深入JDBC sqlserver连接写法的详解
  • 深入oracle特定信息排序的分析
  • 深入分析C中不安全的sprintf与strcpy
  • 哪儿有下载《深入理解Linux内核》这本书?(中文)


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,