for c in代替insert select

來源:互聯網
上載者:User

----過程代碼(insert into比for c in效率高 )
create or replace procedure p_hkb_test is
begin
  begin
    insert into hkb_test1
      (USER_NAME, AGE, USER_ID)
      select a.user_name, a.age, a.user_id from hkb_test a;
  exception
    when others then
      rollback;
  end;
  commit;
  begin
    for c in (select a.user_name, a.age, a.user_id from hkb_test a) loop
      insert into hkb_test1 values (c.user_name, c.age, c.user_id);
    end loop;
  exception
    when others then
      rollback;
  end;
  commit;
end p_hkb_test;

--測試代碼
SQL> select * from hkb_test;
 
USER_NAME AGE USER_ID
--------- --- -------
a          12       1
b          12       2
b          15       3
c          15       4
c          16       5
d          16       5
f          16       5
 
7 rows selected
 
SQL> select * from hkb_test1;
 
USER_NAME AGE USER_ID
--------- --- -------
 
SQL> exec p_hkb_test;
 
PL/SQL procedure successfully completed
 
SQL> select * from hkb_test1;
 
USER_NAME AGE USER_ID
--------- --- -------
a          12       1
b          12       2
b          15       3
c          15       4
c          16       5
d          16       5
f          16       5
a          12       1
b          12       2
b          15       3
c          15       4
c          16       5
d          16       5
f          16       5
 
14 rows selected

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.