调整PL/SQL代码加速执行(2例)

本文探讨了在Oracle PL/SQL中使用PLS_INTEGER代替NUMBER带来的性能提升,并通过实例展示了如何优化MOD函数以减少资源消耗。
1. 调整变量类型NUMBER为PLS_INTEGER。
调整前插入300,000行数据,运行时间00:09:57.30;调整为PLS_INTEGER后,运行时间下降到00:06:47.40。

结论:PLS_INTEGER可以使用更少的内部命令来处理。

2. 调整MOD函数

例:

点击(此处)折叠或打开

  1. BEGIN
  2.     stop_watch.start_timer;
  3. FOR lv_count_num IN 1..10000 LOOP
  4.     IF MOD(lv_count_num, 1000) = 0 THEN
  5.         DBMS_OUTPUT.PUT_LINE('Hit 1000; Total: ' || lv_count_num);
  6.     END IF;
  7. END LOOP;
  8. stop_watch.stop_timer;
  9. END;
  10. /
可调整为,


点击(此处)折叠或打开

  1. DECLARE
  2. lv_count_inc_num PLS_INTEGER := 0;
  3. BEGIN
  4.     stop_watch.start_timer;
  5.     FOR lv_count_num IN 1..10000 LOOP
  6.         lv_count_inc_num := lv_count_inc_num + 1;
  7.         IF lv_count_inc_num = 1000 THEN
  8.             DBMS_OUTPUT.PUT_LINE('Hit 1000; Total: ' || lv_count_num);
  9.             lv_count_inc_num := 0;
  10.         END IF;
  11.     END LOOP;
  12.     stop_watch.stop_timer;
  13. END;
  14. /

我用了自己的一则例子来测试,因代码太长就不贴出来了,实际效果并不明显。调整前00:06:47.40,调整后00:06:10.10。

查阅资料,MOD函数开销比较大。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22621861/viewspace-1283431/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22621861/viewspace-1283431/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值