Chinaunix首页 | 论坛 | 博客
  • 博客访问: 650658
  • 博文数量: 789
  • 博客积分: 5000
  • 博客等级: 大校
  • 技术积分: 4985
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-28 09:29
文章分类

全部博文(789)

文章存档

2011年(1)

2008年(788)

我的朋友

分类:

2008-10-28 09:44:18

 create or replace procedure cp_data2 as

    type TYPE_EMPLOYEES is table of EMPLOYEES%rowtype;

    V_EMPLOYEES TYPE_EMPLOYEES;

    v_table varchar2(30);

    v_sql varchar2(300);

     v_rows number:=5000;

    begin

    execute immediate 'alter session set nls_date_format=''yyyy/mm/dd''';

    v_table := 'employee_cp';

    v_sql := 'insert /*+ APPEND*/ into ' || v_table ||

    ' (EMPLOYEE_ID,

    FIRST_NAME,

    LAST_NAME,

    EMAIL,

    PHONE_NUMBER,

    HIRE_DATE,

    JOB_ID,

    SALARY,

    COMMISSION_PCT,

    MANAGER_ID,

    DEPARTMENT_ID,

    BIRTHDAY)

    values (:1, :2,:3,:4,:5,:6, :7, :8,:9,:10, :11,:12)';


    select * bulk collect into V_EMPLOYEES from employees; --dest table

    for i in 1 .. V_EMPLOYEES.count loop

    execute immediate v_sql

    using V_EMPLOYEES(i).EMPLOYEE_ID, V_EMPLOYEES(i).FIRST_NAME, V_EMPLOYEES(i).LAST_NAME, V_EMPLOYEES(i).EMAIL, V_EMPLOYEES(i).PHONE_NUMBER, V_EMPLOYEES(i).HIRE_DATE, V_EMPLOYEES(i).JOB_ID, V_EMPLOYEES(i).SALARY, V_EMPLOYEES(i).COMMISSION_PCT, V_EMPLOYEES(i).MANAGER_ID, V_EMPLOYEES(i).DEPARTMENT_ID, V_EMPLOYEES(i).BIRTHDAY;

    if mod(i, v_rows) = 0 then

    commit;

    end if;

    end loop;

    commit;

    end;


--------------------next---------------------

阅读(272) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~