我在阅读更多关于BULK COLLECT和dbms_sql的用法,并尝试将其应用于我的一个过程 在我的存储过程中,核心逻辑是从另一个值的INSERT到表中表作为BULK COLLECT和dbms_sql的用法
CREATE OR replace PROCEDURE My_procedure (pi_date IN DATE,
po_error OUT VARCHAR2,
po_error_desc OUT nocopy VARCHAR2)
AS
curr_date DATE;
BEGIN
CURR_DATE := PI_DATE;
INSERT INTO t1
(col1,
col2,
col3,
col4,
col5)
SELECT t2.col1,
t2.col2,
t2.col3,
t2.col4,
CURR_DATE
EXCEPTION
WHEN OTHERS THEN
PO_ERROR := -1;
PO_ERROR_DESC := 'proc nam : '
|| 'my_procedure'
|| ', err_num :'
|| SQLCODE
|| ' | , err_msg :'
|| SQLERRM;
ROLLBACK;
DBMS_SESSION.free_unused_user_memory;
END;
但是因为这将被插入到另一个表中的数据是巨大的,在我的第二次修改程序
我已经使用BULK收集和DBMS_SQL如下
CREATE OR replace PROCEDURE My_procedure (pi_date DATE,
po_error OUT VARCHAR2,
po_error_desc OUT nocopy VARCHAR2)
AS
v_curr_date DATE;
l_col1 dbms_sql.Varchar2_Table;
l_col2 dbms_sql.Varchar2_Table;
l_col3 dbms_sql.Number_Table;
l_col4 dbms_sql.Number_Table;
CURSOR c1 IS
SELECT *
FROM t2;
BEGIN
V_CURR_DATE := PI_DATE;
PO_ERROR := 0;
OPEN c1;
LOOP
FETCH c1 bulk collect INTO l_col1, l_col2, l_col3, l_col4 limit 1000;
forall indx IN 1..l_col1.COUNT
INSERT INTO t2
(col1,
col2,
col3,
col4,
col5)
VALUES (L_col1(indx),
L_col2(indx),
L_col3(indx),
L_col4(indx),
V_CURR_DATE);
EXCEPTION
WHEN OTHERS THEN
PO_ERROR := -1;
PO_ERROR_DESC := 'proc nam : '
|| 'my_procedure'
|| ', err_num :'
|| SQLCODE
|| ' | , err_msg :'
|| SQLERRM;
ROLLBACK;
DBMS_SESSION.free_unused_user_memory;
END;
因此,这里是我的第二个例子中,我已经使用BULK收集按照文档但是
有人能poinpoint的dbms_sql.Varchar2_Table
确切的使用情况如何?
如以上那样,如果COL1的实际长度是VARCHAR2(40),但dbms_sql.Varchar2_Table
使用VARCHAR2(2000)
TYPE varchar2_table IS TABLE OF VARCHAR2(2000) INDEX BY BINARY_INTEGER;
你确切的问题是什么?您提供的代码充斥着语法错误。你应该提供你正在使用的确切源代码,并提到你遇到的问题是什么 – Sathya 2012-04-23 09:51:38
我的问题是我在第二个例子中使用BULK COLLECT和使用dbms_sql做另一个表的INSERT的方法是正确与否。希望这很好。 – ronan 2012-04-23 12:10:06