最近在做測試時,遇到有翻頁功能每頁記錄數為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;