gpt4 book ai didi

oracle - Oracle 中临时表的替代方案

转载 作者:行者123 更新时间:2023-12-01 07:08:05 25 4
gpt4 key购买 nike

  • 在存储过程中创建一个临时表,比如“#Temp”。
  • 使用 select 语句将值插入到“Temp”表中,例如。插入#Temp 从员工中选择*。
  • 现在从这个临时表中提取数据,例如。从 #Temp 中选择 * 其中 #Temp.Id = @id 等等。

  • 如何在 中执行此操作Oracle里面的一个存储过程 ?

    最佳答案

    您要解决的业务问题是什么?在 Oracle 中需要使用临时表的情况极为罕见。你为什么不简单地

    SELECT *
    FROM employees
    WHERE id = p_id_passed_in;

    在其他数据库中,您经常创建临时表,因为读取器会阻止写入器,因此您希望创建数据的单独副本以避免阻塞任何其他 session 。然而,在 Oracle 中,读取器从不阻塞写入器,因此通常不需要保存单独的数据副本。

    在其他数据库中,您创建临时表是因为您不想进行脏读。但是,Oracle 不允许脏读。多版本读取一致性意味着 Oracle 将始终向您显示在查询开始时(或者如果您将事务隔离级别设置为可序列化,则在事务开始时)存在的数据。所以不需要创建临时表来避免脏读。

    如果您真的想在 Oracle 中使用临时表,则不会动态创建该表。在创建存储过程之前,您将创建一个全局临时表。表结构对所有 session 可见,但数据仅对插入它的 session 可见。您将在过程中填充临时表,然后查询该表。就像是
    CREATE GLOBAL TEMPORARY TABLE temp_emp (
    empno number,
    ename varchar2(10),
    job varchar2(9),
    mgr number,
    sal number(7,2)
    )
    ON COMMIT PRESERVE ROWS;

    CREATE OR REPLACE PROCEDURE populate_temp_emp
    AS
    BEGIN
    INSERT INTO temp_emp( empno,
    ename,
    job,
    mgr,
    sal )
    SELECT empno,
    ename,
    job,
    mgr,
    sal
    FROM emp;
    END;
    /

    SQL> begin
    2 populate_temp_emp;
    3 end;
    4 /

    PL/SQL procedure successfully completed.

    SQL> select *
    2 from temp_emp;

    EMPNO ENAME JOB MGR SAL
    ---------- ---------- --------- ---------- ----------
    7623 PAV Dev
    7369 smith CLERK 7902 800
    7499 ALLEN SALESMAN 7698 1600
    7521 WARD SALESMAN 7698 1250
    7566 JONES MANAGER 7839 2975
    7654 MARTIN SALESMAN 7698 1250
    7698 BLAKE MANAGER 7839 2850
    7782 CLARK MANAGER 7839 2450
    7788 SCOTT ANALYST 7566 3000
    7839 KING PRESIDENT 5000
    7844 TURNER SALESMAN 7698 1500
    7876 ADAMS CLERK 7788 1110
    7900 SM0 CLERK 7698 950
    7902 FORD ANALYST 7566 3000
    7934 MILLER CLERK 7782 1300
    1234 BAR

    16 rows selected.

    不过,正如我所说,在 Oracle 中实际上想要使用临时表是非常不寻常的。

    关于oracle - Oracle 中临时表的替代方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7598631/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com