Oracle 怎么同時插入多條數據?


SQL語句向表中插入多個值的話,如果如下語句

INSERT INTO 某表 VALUES(各個值),VALUES(各個值),.....;

這樣會報錯的,因為oracle是不支持這種寫法的,如果多個INSERT INTO VALUEES(各個值);這樣以“;”隔開一同執行也是不行的,oracle也是不支持的。

       不過MySQL這兩種方式都是支持的。在MySQL中還可以使用如下格式的插入語句:

示例:
insert into persons 
(id_p, lastname , firstName, city )
values
(200,'haha' , 'deng' , 'shenzhen'),
(201,'haha2' , 'deng' , 'GD'),
(202,'haha3' , 'deng' , 'Beijing');

SQL Server也是不支持這兩種寫法的。

ORACLE 的方法:

"INSERT ALL INTO  a表
VALUES(各個值)  
INTO a表 VALUES (其它值) 
INTO a表 VALUES(其它值) .... 再跟一個SELECT 語句"
SELECT 1 FROM DUAL

后邊跟的SELECT 語句我們可以從虛擬表里查如 SELECT 1 FROM DUAL。注意后邊跟的SELECT語句可以隨意,不過不是把它SELECT出來的內容插入前邊的表里,而是起到前邊的多個數據每次插入多少行的作用,這個多少行是和后邊跟的SELECT語句查出來幾條而定的,如后邊的跟的SELECT 語句查出了15條記錄,那么前邊的"INSERT ALL INTO  a表 VALUES(各個值1)  INTO a表 VALUES (其它值2) INTO a表 VALUES(其它值3)"就會先插入值1對應的各個字段插入15條記錄,然后插入值2各個對應的字段15條記錄,然后插入值3對應的各個字段15條記錄,也就是說有點按列插入的意思。

       我們要的是批量插入多個VALUES這樣的一條記錄,所以后邊的SELECT 語句只要能查出一條記錄就行,建議大家后邊用SELECT 1 FROM DUAL

INSERT ALL INTO 表名 VALUES('值1','值2'...) INTO 表名 VALUES('值1','值2'...) SELECT 1 FROM DUAL;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM