Oracle中如何使用單個inert語句實現(xiàn)插入多行
前言
最近項目中使用到了Oracle數(shù)據(jù)庫,由于Oracle數(shù)據(jù)庫我已經(jīng)好幾年沒用過了,最近幾年用的幾乎都是MySQL數(shù)據(jù)庫。
在使用Oracle數(shù)據(jù)庫編寫SQL語句的過程中,發(fā)現(xiàn)了有一些函數(shù)、語法、句式是不太熟悉的,或者說是和MySQL有些區(qū)別的;因此最近我打算復習一下Oracle,同時在接下來的一段時間內(nèi)也會不定期更新一些關于Oracle數(shù)據(jù)庫的學習日記(文章),結合我個人的學習心得,也算是溫故而知新吧,希望能幫助到有需要的同伴。
問題現(xiàn)象
今天在學習中遇到一個問題:
如何在Oracle中,使用單個inert語句實現(xiàn)插入多行記錄呢?
問題分析
由于最近幾年都是使用MySQL數(shù)據(jù)庫比較多,因此一開始遇到這個問題的時候,我其實是直接使用了MySQL中語法來解決這個問題的,下面將使用Oracle最經(jīng)典的鏈接工具【PLSQL Developer】來進行測試,過程如下:
先簡單建表:
-- 建表語句 CREATE TABLE BIZ_BREED_INFO ( breed_id INTEGER PRIMARY KEY, biz_breed VARCHAR2(255), memo VARCHAR2(255) ); COMMENT ON TABLE BIZ_BREED_INFO IS '業(yè)務品種表'; COMMENT ON COLUMN BIZ_BREED_INFO.breed_id IS '品種id'; COMMENT ON COLUMN BIZ_BREED_INFO.biz_breed IS '業(yè)務品種名稱'; COMMENT ON COLUMN BIZ_BREED_INFO.memo IS '備注';
然后使用一個insert語句插入多行記錄:
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (1, '稻谷', '用于糧食生產(chǎn)和飼料'), (2, '小麥', '用于面粉生產(chǎn)和飼料'), (3, '玉米', '用于飼料、淀粉和乙醇生產(chǎn)'), (4, '大豆', '用于食用油和蛋白質(zhì)飼料'), (5, '棉花', '用于紡織工業(yè)'), (6, '花生', '用于食用油和蛋白質(zhì)'), (7, '馬鈴薯', '用于食品和工業(yè)淀粉'), (8, '甘蔗', '用于制糖和乙醇生產(chǎn)'), (9, '蘋果', '用于鮮食和果汁'), (10, '橙子', '用于鮮食和果汁'), (11, '茶葉', '用于飲品和出口'), (12, '蔬菜', '用于鮮食和加工'), (13, '奶牛', '用于牛奶生產(chǎn)'), (14, '豬', '用于肉類生產(chǎn)'), (15, '雞', '用于蛋和肉類生產(chǎn)'), (16, '魚類', '用于水產(chǎn)養(yǎng)殖'), (17, '蝦類', '用于水產(chǎn)養(yǎng)殖'), (18, '蟹類', '用于水產(chǎn)養(yǎng)殖'), (19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等'), (20, '煙草', '用于卷煙和其他煙草制品');
沒想到一執(zhí)行就報錯:
查了一下發(fā)現(xiàn),原來是Oracle不支持這樣的寫法。
雖然我們都知道可以執(zhí)行多個inert語句來實現(xiàn)多行數(shù)據(jù)記錄的插入,如下:
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (1, '稻谷', '用于糧食生產(chǎn)和飼料'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (2, '小麥', '用于面粉生產(chǎn)和飼料'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (3, '玉米', '用于飼料、淀粉和乙醇生產(chǎn)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (4, '大豆', '用于食用油和蛋白質(zhì)飼料'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (5, '棉花', '用于紡織工業(yè)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (6, '花生', '用于食用油和蛋白質(zhì)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (7, '馬鈴薯', '用于食品和工業(yè)淀粉'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (8, '甘蔗', '用于制糖和乙醇生產(chǎn)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (9, '蘋果', '用于鮮食和果汁'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (10, '橙子', '用于鮮食和果汁'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (11, '茶葉', '用于飲品和出口'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (12, '蔬菜', '用于鮮食和加工'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (13, '奶牛', '用于牛奶生產(chǎn)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (14, '豬', '用于肉類生產(chǎn)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (15, '雞', '用于蛋和肉類生產(chǎn)'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (16, '魚類', '用于水產(chǎn)養(yǎng)殖'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (17, '蝦類', '用于水產(chǎn)養(yǎng)殖'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (18, '蟹類', '用于水產(chǎn)養(yǎng)殖'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等'); INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (20, '煙草', '用于卷煙和其他煙草制品');
但是,難道Oracle并不支持使用單個inert語句實現(xiàn)插入多行記錄嗎?
抱著這樣的疑問,我再次搜集了相關資料,才發(fā)現(xiàn)其實方法還是有的,只是sql寫起來會顯得很冗余。
解決方法
1、insert into ... union all句式
句式規(guī)則如下:
INSERT INTO 表名(字段列表) select 字段值列表 from dual union all select 字段值列表 from dual union all ......
SQL示例如下:
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) SELECT 1, '稻谷', '用于糧食生產(chǎn)和飼料' FROM DUAL UNION ALL SELECT 2, '小麥', '用于面粉生產(chǎn)和飼料' FROM DUAL UNION ALL SELECT 3, '玉米', '用于飼料、淀粉和乙醇生產(chǎn)' FROM DUAL UNION ALL SELECT 4, '大豆', '用于食用油和蛋白質(zhì)飼料' FROM DUAL UNION ALL SELECT 5, '棉花', '用于紡織工業(yè)' FROM DUAL UNION ALL SELECT 6, '花生', '用于食用油和蛋白質(zhì)' FROM DUAL UNION ALL SELECT 7, '馬鈴薯', '用于食品和工業(yè)淀粉' FROM DUAL UNION ALL SELECT 8, '甘蔗', '用于制糖和乙醇生產(chǎn)' FROM DUAL UNION ALL SELECT 9, '蘋果', '用于鮮食和果汁' FROM DUAL UNION ALL SELECT 10, '橙子', '用于鮮食和果汁' FROM DUAL UNION ALL SELECT 11, '茶葉', '用于飲品和出口' FROM DUAL UNION ALL SELECT 12, '蔬菜', '用于鮮食和加工' FROM DUAL UNION ALL SELECT 13, '奶牛', '用于牛奶生產(chǎn)' FROM DUAL UNION ALL SELECT 14, '豬', '用于肉類生產(chǎn)' FROM DUAL UNION ALL SELECT 15, '雞', '用于蛋和肉類生產(chǎn)' FROM DUAL UNION ALL SELECT 16, '魚類', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL SELECT 17, '蝦類', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL SELECT 18, '蟹類', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL SELECT 19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等' FROM DUAL UNION ALL SELECT 20, '煙草', '用于卷煙和其他煙草制品' FROM DUAL;
執(zhí)行成功:
執(zhí)行成功后記得提交事務:
表數(shù)據(jù)如下:
2、insert all into ...select 1 from dual句式
句式規(guī)則如下:
INSERT ALL INTO 表名(字段列表) VALUES (字段值列表) INTO 表名(字段列表) VALUES (字段值列表) ... SELECT 1 FROM DUAL;
由于在測試完第1種方法后,表中已經(jīng)插入了20行數(shù)據(jù),所以在測試第2種方法之前,需要先刪除掉,執(zhí)行刪除sql:
選擇是,然后提交事務:
再次查詢表數(shù)據(jù):
然后使用第2種句式插入數(shù)據(jù),SQL示例如下:
INSERT ALL INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (1, '稻谷', '用于糧食生產(chǎn)和飼料') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (2, '小麥', '用于面粉生產(chǎn)和飼料') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (3, '玉米', '用于飼料、淀粉和乙醇生產(chǎn)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (4, '大豆', '用于食用油和蛋白質(zhì)飼料') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (5, '棉花', '用于紡織工業(yè)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (6, '花生', '用于食用油和蛋白質(zhì)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (7, '馬鈴薯', '用于食品和工業(yè)淀粉') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (8, '甘蔗', '用于制糖和乙醇生產(chǎn)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (9, '蘋果', '用于鮮食和果汁') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (10, '橙子', '用于鮮食和果汁') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (11, '茶葉', '用于飲品和出口') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (12, '蔬菜', '用于鮮食和加工') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (13, '奶牛', '用于牛奶生產(chǎn)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (14, '豬', '用于肉類生產(chǎn)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (15, '雞', '用于蛋和肉類生產(chǎn)') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (16, '魚類', '用于水產(chǎn)養(yǎng)殖') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (17, '蝦類', '用于水產(chǎn)養(yǎng)殖') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (18, '蟹類', '用于水產(chǎn)養(yǎng)殖') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等') INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (20, '煙草', '用于卷煙和其他煙草制品') SELECT 1 FROM DUAL;
執(zhí)行成功:
提交事務:
表數(shù)據(jù)如下:
總結
可以看到在Oracle中,確實是可以通過單個inert語句實現(xiàn)插入多行記錄的?。?!
但是缺點也很明顯,就是和MySQL的語句相比,SQL代碼???很冗余。尤其是第2種句式,書寫起來的代碼,甚至比直接寫20個insert語句還要多。當然第一種句式書寫起來的代碼和直接寫20個insert語句其實也沒差多少。
相信大家都已經(jīng)了解并學會了在Oracle中使用單個inert語句實現(xiàn)插入多行記錄。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
ORACLE 正則解決初使化數(shù)據(jù)格式不一致
在初使化用戶基礎數(shù)據(jù)時會出現(xiàn)一些數(shù)據(jù)格式不正確的情況。。2009-05-05Oracle實現(xiàn)透明數(shù)據(jù)加密的代碼示例
透明數(shù)據(jù)加密(TDE)是一種用于保護數(shù)據(jù)庫中靜態(tài)數(shù)據(jù)的加密技術,TDE通過自動加密數(shù)據(jù)庫文件和日志文件,確保數(shù)據(jù)在磁盤上是加密的,從而防止未經(jīng)授權的訪問,以下以 Microsoft SQL Server 為例,實現(xiàn) TDE 的步驟和代碼示例,需要的朋友可以參考下2024-09-09Oracle中時間日期轉化函數(shù)to_date和to_char的具體使用
時間日期轉化函數(shù)在工作中經(jīng)常可以使用的到,本文主要介紹了Oracle中時間日期轉化函數(shù)to_date和to_char的具體使用,具有一定的參考價值,感興趣的可以了解一下2023-05-05oracle 11g的警告日志和監(jiān)聽日志的刪除方法
這篇文章主要介紹了oracle 11g的警告日志和監(jiān)聽日志的刪除方法,需要的朋友可以參考下2014-07-07Oracle開發(fā)之分析函數(shù)簡介Over用法
本文主要是對Oracle分析函數(shù)概念的簡單介紹,同時講解了Over函數(shù)的用法,希望對大家學習分析函數(shù)有所幫助。2016-05-05