insert into persons (id_p, lastname , firstName, city ) values (200,'haha' , 'deng' , 'shenzhen'), (201,'haha2' , 'deng' , 'GD'), (202,'haha3' , 'deng' , 'Beijing');
這是mysql的插入語句。
但是我們在oracle中是報錯的,語句l
那怎么辦呢
也許熟悉oracle數據庫的可能知道從oracle9i版本以后,可以使用一種方法即:
"INSERT ALL INTO a表
VALUES(各個值)
INTO a表 VALUES (其它值)
INTO a表 VALUES(其它值) .... 再跟一個SELECT 語句"。
例如
INSERT
ALL
INTO
d5000.ac_terminal_connect_info
(
id ,
feeder_id,
esn ,
name ,
description
)
VALUES
(
(
select
id
from
d5000.dms_terminal_info
where
esn_id = '025BHN6RJB504521' limit 1
)
,
(
select
feeder_id
from
d5000.dms_terminal_info
where
esn_id = '025BHN6RJB504521' limit 1
)
,
'025BHN6RJB504521',
'大廠地稅局TTU-華為六合管理' ,
''
)
INTO
d5000.ac_terminal_connect_info
(
id ,
feeder_id,
esn ,
name ,
description
)
VALUES
(
(
select
id
from
d5000.dms_terminal_info
where
esn_id = '025BHN6RJB503985' limit 1
)
,
(
select
feeder_id
from
d5000.dms_terminal_info
where
esn_id = '025BHN6RJB503985' limit 1
)
,
'025BHN6RJB503985' ,
'淳溪東甘#3配變TTU-華為高淳管理',
''
)
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。