利用ROWID快速执行关联更新
一.构造相关表P1,P2
create table p1(id int,name char(10));
create table p2(id int,name char(10));
二.批量插入数据
begin
for i in 1 .. 100000
loop
insert into p1 values(i,'a'||i);
end loop
;
commit;
end;
begin
for i in 1 .. 100000
loop
insert into p2 values(i,'b'||i);
end loop
;
commit;
end;
三 对比测试
本来的需求:
update p1 set name=(select name from p2 where p1.id=p2.id);
用p2表的name列来更新p1表的name列
SQL> set timing on
SQL> update p1 set name=(select name from p2 where p1.id=p2.id);
100000 rows updated.
Elapsed: 00:09:59.68
直接update花了10分钟,太慢了
利用rowid更新
DECLARE
CURSOR cur IS
SELECT
b.name, a.ROWID ROW_ID
FROM p1 a, p2 b
WHERE a.id = b.id
ORDER BY a.ROWID;
V_COUNTER NUMBER;
BEGIN
V_COUNTER := 0;
FOR row IN cur LOOP
UPDATE p1
SET name = row.name
WHERE ROWID = row.ROW_ID;
V_COUNTER := V_COUNTER + 1;
IF (V_COUNTER >= 1000) THEN
COMMIT;
V_COUNTER := 0;
END IF;
END LOOP;
COMMIT;
END;
PL/SQL procedure successfully completed.
Elapsed: 00:00:19.56
差距太明显了--------------------------------------------------
最新文章
- CSS项目学习总结
- MicroERP软件更新记录2.1
- 判断远程图片是否存在【适用于windows服务器】
- winfrom之动态控件生成以及保存动态空间的数据
- 【python】求水仙数
- WCF技术剖析之二十七: 如何将一个服务发布成WSDL[基于WS-MEX的实现](提供模拟程序)
- [JAVA第二课] java命名规则
- node实现一个WEBSOCKET服务器
- EasyUI easyui-combobox实现数据联动
- Selenium-java测试环境搭建
- 实验吧 burpsuie拦截修改请求
- 好用的 Chrome 插件,提升你的学习工作效率
- 【357】sorted 函数高级用法
- [Spark Core] Spark 在 IDEA 下编程
- AngularJS入门基础——表达式
- 温故而知新 监听 XMLHttpRequest 发起请求
- SQL 2008登录的域账户与数据库服务器不再同一个域的 处理方法
- 337BRoutine Problem
- 关于动态门户WEB博雅互动的源代码(HTML+CSS+javascript)
- spring基础---->;spring自定义标签(一)