Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/date/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Oracle中临时表的替代方案 在存储过程中创建一个临时表,例如“Temp”。 使用select语句将值插入“Temp”表,例如,将值插入Temp select*from EMPLOYEE。 现在从这个临时表中提取数据,例如,选择*from Temp,其中Temp.Id=@Id&等等。_Oracle_Plsql - Fatal编程技术网

Oracle中临时表的替代方案 在存储过程中创建一个临时表,例如“Temp”。 使用select语句将值插入“Temp”表,例如,将值插入Temp select*from EMPLOYEE。 现在从这个临时表中提取数据,例如,选择*from Temp,其中Temp.Id=@Id&等等。

Oracle中临时表的替代方案 在存储过程中创建一个临时表,例如“Temp”。 使用select语句将值插入“Temp”表,例如,将值插入Temp select*from EMPLOYEE。 现在从这个临时表中提取数据,例如,选择*from Temp,其中Temp.Id=@Id&等等。,oracle,plsql,Oracle,Plsql,如何在Oracle存储过程中执行此操作?您试图解决的业务问题是什么?在Oracle中需要使用临时表的情况非常罕见。你为什么不干脆 SELECT * FROM employees WHERE id = p_id_passed_in; 在其他数据库中,通常会创建临时表,因为读卡器会阻止写入程序,所以需要创建数据的单独副本,以避免阻塞任何其他会话。然而,在Oracle中,读卡器从不阻止写入程序,因此通常不需要保存数据的单独副本 在其他数据库中,创建临时表是因为不想进行脏读。然而,Oracle不

如何在Oracle存储过程中执行此操作?

您试图解决的业务问题是什么?在Oracle中需要使用临时表的情况非常罕见。你为什么不干脆

SELECT *
  FROM employees
 WHERE id = p_id_passed_in;
在其他数据库中,通常会创建临时表,因为读卡器会阻止写入程序,所以需要创建数据的单独副本,以避免阻塞任何其他会话。然而,在Oracle中,读卡器从不阻止写入程序,因此通常不需要保存数据的单独副本

在其他数据库中,创建临时表是因为不想进行脏读。然而,Oracle不允许脏读。多版本读取一致性意味着,如果已将事务隔离级别设置为serializable,Oracle将始终向您显示查询启动时或事务启动时存在的数据。因此,不需要创建临时表来避免脏读

如果确实希望在Oracle中使用临时表,则不会动态创建该表。您应该在创建存储过程之前创建一个全局临时表。表结构将对所有会话可见,但数据将仅对插入它的会话可见。您将在过程中填充临时表,然后查询该表。差不多

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中,实际想要使用临时表是非常不寻常的。

创建一个全局临时表

CREATE GLOBAL TEMPORARY TABLE <your_table>
ON COMMIT PRESERVE ROWS   # If needed.  Depends on your needs.
AS SELECT <your_select_query>;
然后,您可以根据需要在程序期间从表中进行选择


我感谢你努力回答我的问题,但这不是我想要的。简单地说,我需要一个替代逻辑来代替Oracle存储过程中的临时表。@nylon610-你能解释一下为什么不能使用全局临时表吗?从技术上讲,使用动态SQL在存储过程中创建对象是可能的,但这种额外的复杂性是非常罕见的。特别是在多用户系统中,因为在Oracle中不可能有一个作用域仅限于会话的对象。我在存储过程中有一个select查询。我必须打印查询结果中的行数,然后打印查询结果数据本身。我该怎么做?全局临时表不适用于我,因为在事务结束后不会删除全局临时表,只删除全局临时表的数据。使用这种设计是非常危险的。@meir-这是家庭作业吗?如果print意味着调用dbms_输出,那么这不是在生产存储过程中执行的操作,因为不能保证调用方能够对结果执行任何操作。客户机打印结果要明智得多,因为客户机负责管理表示层,并让客户机确定提取的行数。如果您希望返回的行数超过一小部分,那么将结果和计数显示为SQL*Plus将更有效。