oracle快速迴圈插入資料

來源:互聯網
上載者:User

     最近在做測試時,遇到有翻頁功能每頁記錄數為500的情況,並且記錄是有很多張表關聯起來的。如果一條一條的插記錄,那顯然是不現實的。那麼我們可以採取什麼比較好的方法來進行測試呢?答案肯定是有的。

     下面就介紹兩種比較常用的方法:

      一:最簡單有效方法。修改程式中的分頁記錄數,如將分頁記錄數改小,那樣就可以很容易的插入資料進行測試,測試壓力也會驟降。

      例如:可以將以下代碼中的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 in4..100 loop
INSERT INTO rfid_fixed_heart VALUES(SYSDATE+i,i);
end LOOP;
END;
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.