Oracle批量插入测试数据的方法
需要:经常碰到需要插入大量测试数据的情景,如果一条一条插入,太麻烦。可以采用序列+函数+匿名块(或存储过程)的方式解决。
下列步骤演示了插入1000条数据的方法:
1 创建表
create table emp (id number(4),name varchar2(10));
2 创建序列
create sequence my_seq increment by 1 start with 1 maxvalue 1000;
3 创建获取序列的函数
create or replace function get_seq return number
as
seq number;
begin
select my_seq.nextval into seq from dual;
return seq;
end get_seq;
/
4 创建匿名块
DECLARE
i INT;
testid number(4);
BEGIN
i := 0;
WHILE(i < 1000)
LOOP
i := i + 1;
testid := get_seq;
INSERT INTO EMP(ID,NAME) VALUES(testid, 'Zheng');
END LOOP;
COMMIT;
END;
/
注:第4步也可以使用存储过程
create or replace procedure my_proc as
BEGIN
DECLARE
i INT;
testid number(4);
BEGIN
i := 0;
WHILE(i < 1000)
LOOP
i := i + 1;
testid := get_seq;
INSERT INTO EMP(ID,NAME) VALUES(testid, 'Zheng');
END LOOP;
COMMIT;
END;
END;
/
exec my_proc;
(注:存储过程的定义和执行是分开的。所以这里调用exec my_proc来执行存储过程。而匿名块则定义完即执行,因为匿名块没有名称,无法采用“exec XXX名称“的方式来调用。这是匿名块和存储过程的区别之一。)
5 检验
SQL> select count(*) from emp;
COUNT(*)
----------
1000
SQL> select max(id) from emp;
MAX(ID)
----------
1000
SQL> select min(id) from emp;
MIN(ID)
----------
1
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29485627/viewspace-1852570/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29485627/viewspace-1852570/