oracle快速循环插入数据

  下面就介绍两种比较常用的方法:

      一:最简单有效的方法。修改程序中的分页记录数,如将分页记录数改小,那样就可以很容易的插入数据进行测试,测试压力也会骤降。

      例如:可以将以下代码中的ac_page_record_cnt改为2,那样造数据测试的时间就会很少了。

PROCEDURE p_query_typelist(              ar_cur             OUT NOCOPY ref_data,
              ac_page_record_cnt OUT VARCHAR2,--页记录数
                ai_dm              OUT NUMBER,
              ac_sm              OUT VARCHAR2) IS
BEGIN
  OPEN ar_cur FOR
    SELECT '01' VALUE, '用户编号' NAME
     FROM dual
    UNION ALL
    SELECT '02' VALUE, '抄表段' NAME
     FROM dual
    UNION ALL
    SELECT '03' VALUE, '抄表员' NAME
     FROM dual;
  ac_page_record_cnt := '500';
  ai_dm              := 1;
  ac_sm              := 'OK';
EXCEPTION
  WHEN OTHERS THEN
    BEGIN
      ai_dm := -1;
      ac_sm := pkg_sp_msg.f_msg('errors.general', '查询异常,详细原因为{0}', SQLERRM);
    END;
END;

 

 

   二:有的情况下是不允许修改源程序来进行测试的,那么大的数据量该怎么办呢? 这里提供一种简单有效的方法,利用循环快速的向oracle表中插入数据。下面建一个测试表,作为实验实验。

--若存在rfid_fixed_heart表,则删除

 

begin
execute immediate 'drop table rfid_fixed_heart';
exception when others then
null;
end;

 

-- 创建rfid_fixed_heart表

CREATE TABLE rfid_fixed_heart
(   input_date date,
    heart_active   VARCHAR2(2)
);

 

--使用循环快速向oracle表中插入数据

declare 
i  NUMBER;
begin
for i in 4..100 loop
INSERT INTO rfid_fixed_heart VALUES(SYSDATE+i,i);
end LOOP;
END;
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值