Oracle 批量处理数据

本文介绍了两种在Oracle数据库中进行批量数据处理的方法:1) 使用PL/SQL循环更新数据,通过COMMIT每处理1000条记录来提高效率;2) 批量插入数据,包括使用APPEND Hint减少日志写入以及通过EXPDP/IMPDP工具快速迁移数据。
摘要由CSDN通过智能技术生成

1、大批量的更新update表的数据

DECLARE

CURSOR CUR_B IS

SELECT COUNT(1)

FROM BatchCode A, BatchCode_dpp_201709071800 B

where A.entid = B.entid

and A.angleid = B.angleid

and A.goodsid = B.goodsid

and A.batchcode = B.batchcode

and A.valdate = B.valdate

ORDER BY A.ROWID; ---如果表的数据量不是很大,可以不用 order by rowid

V_COUNTER NUMBER;

BEGIN

V_COUNTER := 0;

FOR ROW_B IN CUR_B LOOP

UPDATE BatchCode

SET valdate = ROW_B.valdate

WHERE ROWID = ROW_B.ROW_ID;

V_COUNTER := V_COUNTER + 1;

IF (V_COUNTER >= 1000) THEN

COMMIT;

V_COUNTER := 0;

END IF;

END LOOP;

COMMIT;

END;

2、大批量的插入数据

方法1:

用Hint 提示减少操作时间

    INSERT   /*+Append*/   INTO     tab1 

                SELECT   *   FROM   tab2;

采用不写日志及使用Hint提示减少数据操作的时间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值