zoukankan      html  css  js  c++  java
  • 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 表,且则表照旧在数据字典中存在的。




    版权声明: 原创作品,答理转载,转载时请务必以超链接方式标明文章 原始因由 、作者信息和本声明。不然将追究法则责任。

  • 相关阅读:
    Robot Framework-资源文件的使用方法(7)
    Robot Framework-用户关键字的使用方法(6)
    robotframework 新建UI自动化测试用例实例一(2)
    robotframework--登录接口,post传递多个参数、及获取content中指定属性的值(5)
    robotframework基础知识(2)
    win7如何打开防火墙某个端口的tcp连接
    外观模式
    享元模式
    代理模式
    模板模式
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1975924.html
Copyright © 2011-2022 走看看