亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Oracle中如何使用單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行

 更新時(shí)間:2025年06月06日 09:59:12   作者:Stephen·You  
這篇文章主要介紹了Oracle中如何使用單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言

最近項(xiàng)目中使用到了Oracle數(shù)據(jù)庫(kù),由于Oracle數(shù)據(jù)庫(kù)我已經(jīng)好幾年沒(méi)用過(guò)了,最近幾年用的幾乎都是MySQL數(shù)據(jù)庫(kù)。

在使用Oracle數(shù)據(jù)庫(kù)編寫(xiě)SQL語(yǔ)句的過(guò)程中,發(fā)現(xiàn)了有一些函數(shù)、語(yǔ)法、句式是不太熟悉的,或者說(shuō)是和MySQL有些區(qū)別的;因此最近我打算復(fù)習(xí)一下Oracle,同時(shí)在接下來(lái)的一段時(shí)間內(nèi)也會(huì)不定期更新一些關(guān)于Oracle數(shù)據(jù)庫(kù)的學(xué)習(xí)日記(文章),結(jié)合我個(gè)人的學(xué)習(xí)心得,也算是溫故而知新吧,希望能幫助到有需要的同伴。

問(wèn)題現(xiàn)象

今天在學(xué)習(xí)中遇到一個(gè)問(wèn)題:

如何在Oracle中,使用單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行記錄呢?

問(wèn)題分析

由于最近幾年都是使用MySQL數(shù)據(jù)庫(kù)比較多,因此一開(kāi)始遇到這個(gè)問(wèn)題的時(shí)候,我其實(shí)是直接使用了MySQL中語(yǔ)法來(lái)解決這個(gè)問(wèn)題的,下面將使用Oracle最經(jīng)典的鏈接工具【PLSQL Developer】來(lái)進(jìn)行測(cè)試,過(guò)程如下:

先簡(jiǎn)單建表:

-- 建表語(yǔ)句
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è)務(wù)品種表';
COMMENT ON COLUMN BIZ_BREED_INFO.breed_id IS '品種id';
COMMENT ON COLUMN BIZ_BREED_INFO.biz_breed IS '業(yè)務(wù)品種名稱(chēng)';
COMMENT ON COLUMN BIZ_BREED_INFO.memo IS '備注';

然后使用一個(gè)insert語(yǔ)句插入多行記錄:

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, '蘋(píng)果', '用于鮮食和果汁'),
(10, '橙子', '用于鮮食和果汁'),
(11, '茶葉', '用于飲品和出口'),
(12, '蔬菜', '用于鮮食和加工'),
(13, '奶牛', '用于牛奶生產(chǎn)'),
(14, '豬', '用于肉類(lèi)生產(chǎn)'),
(15, '雞', '用于蛋和肉類(lèi)生產(chǎn)'),
(16, '魚(yú)類(lèi)', '用于水產(chǎn)養(yǎng)殖'),
(17, '蝦類(lèi)', '用于水產(chǎn)養(yǎng)殖'),
(18, '蟹類(lèi)', '用于水產(chǎn)養(yǎng)殖'),
(19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等'),
(20, '煙草', '用于卷煙和其他煙草制品');

沒(méi)想到一執(zhí)行就報(bào)錯(cuò):

查了一下發(fā)現(xiàn),原來(lái)是Oracle不支持這樣的寫(xiě)法。

雖然我們都知道可以執(zhí)行多個(gè)inert語(yǔ)句來(lái)實(shí)現(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, '蘋(píng)果', '用于鮮食和果汁');
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, '豬', '用于肉類(lèi)生產(chǎn)');
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (15, '雞', '用于蛋和肉類(lèi)生產(chǎn)');
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (16, '魚(yú)類(lèi)', '用于水產(chǎn)養(yǎng)殖');
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (17, '蝦類(lèi)', '用于水產(chǎn)養(yǎng)殖');
INSERT INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (18, '蟹類(lèi)', '用于水產(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并不支持使用單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行記錄嗎?

抱著這樣的疑問(wèn),我再次搜集了相關(guān)資料,才發(fā)現(xiàn)其實(shí)方法還是有的,只是sql寫(xiě)起來(lái)會(huì)顯得很冗余。

解決方法

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, '蘋(píng)果', '用于鮮食和果汁' 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, '豬', '用于肉類(lèi)生產(chǎn)' FROM DUAL UNION ALL
SELECT 15, '雞', '用于蛋和肉類(lèi)生產(chǎn)' FROM DUAL UNION ALL
SELECT 16, '魚(yú)類(lèi)', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL
SELECT 17, '蝦類(lèi)', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL
SELECT 18, '蟹類(lèi)', '用于水產(chǎn)養(yǎng)殖' FROM DUAL UNION ALL
SELECT 19, '蜂產(chǎn)品', '用于蜂蜜、蜂王漿等' FROM DUAL UNION ALL
SELECT 20, '煙草', '用于卷煙和其他煙草制品' FROM DUAL;

執(zhí)行成功:

執(zhí)行成功后記得提交事務(wù):

表數(shù)據(jù)如下:

2、insert all into ...select 1 from dual句式

句式規(guī)則如下:

INSERT ALL
INTO 表名(字段列表) VALUES (字段值列表)
INTO 表名(字段列表) VALUES (字段值列表)
...
SELECT 1 FROM DUAL;

由于在測(cè)試完第1種方法后,表中已經(jīng)插入了20行數(shù)據(jù),所以在測(cè)試第2種方法之前,需要先刪除掉,執(zhí)行刪除sql:

選擇是,然后提交事務(wù):

再次查詢(xún)表數(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, '蘋(píng)果', '用于鮮食和果汁')
  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, '豬', '用于肉類(lèi)生產(chǎn)')
  INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (15, '雞', '用于蛋和肉類(lèi)生產(chǎn)')
  INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (16, '魚(yú)類(lèi)', '用于水產(chǎn)養(yǎng)殖')
  INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (17, '蝦類(lèi)', '用于水產(chǎn)養(yǎng)殖')
  INTO BIZ_BREED_INFO (BREED_ID, BIZ_BREED, MEMO) VALUES (18, '蟹類(lèi)', '用于水產(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í)行成功:

提交事務(wù):

表數(shù)據(jù)如下:

總結(jié)

可以看到在Oracle中,確實(shí)是可以通過(guò)單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行記錄的?。。?/strong>

但是缺點(diǎn)也很明顯,就是和MySQL的語(yǔ)句相比,SQL代碼???很冗余。尤其是第2種句式,書(shū)寫(xiě)起來(lái)的代碼,甚至比直接寫(xiě)20個(gè)insert語(yǔ)句還要多。當(dāng)然第一種句式書(shū)寫(xiě)起來(lái)的代碼和直接寫(xiě)20個(gè)insert語(yǔ)句其實(shí)也沒(méi)差多少。

相信大家都已經(jīng)了解并學(xué)會(huì)了在Oracle中使用單個(gè)inert語(yǔ)句實(shí)現(xiàn)插入多行記錄。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • ORACLE 正則解決初使化數(shù)據(jù)格式不一致

    ORACLE 正則解決初使化數(shù)據(jù)格式不一致

    在初使化用戶(hù)基礎(chǔ)數(shù)據(jù)時(shí)會(huì)出現(xiàn)一些數(shù)據(jù)格式不正確的情況。。
    2009-05-05
  • Oracle實(shí)現(xiàn)透明數(shù)據(jù)加密的代碼示例

    Oracle實(shí)現(xiàn)透明數(shù)據(jù)加密的代碼示例

    透明數(shù)據(jù)加密(TDE)是一種用于保護(hù)數(shù)據(jù)庫(kù)中靜態(tài)數(shù)據(jù)的加密技術(shù),TDE通過(guò)自動(dòng)加密數(shù)據(jù)庫(kù)文件和日志文件,確保數(shù)據(jù)在磁盤(pán)上是加密的,從而防止未經(jīng)授權(quán)的訪問(wèn),以下以 Microsoft SQL Server 為例,實(shí)現(xiàn) TDE 的步驟和代碼示例,需要的朋友可以參考下
    2024-09-09
  • Oracle SQL注入的實(shí)例總結(jié)

    Oracle SQL注入的實(shí)例總結(jié)

    在網(wǎng)絡(luò)中,數(shù)據(jù)庫(kù)驅(qū)動(dòng)的Web應(yīng)用隨處可見(jiàn),由此而存在的SQL注入是影響企業(yè)運(yùn)營(yíng)且最具破壞性的漏洞之一,下面這篇文章主要給大家介紹了關(guān)于Oracle SQL注入的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • Oracle學(xué)習(xí)筆記(五)

    Oracle學(xué)習(xí)筆記(五)

    最近需要用的oracle,所以大家好好的學(xué)習(xí)下基礎(chǔ)并整理下資料,希望能幫助到需要的朋友。
    2011-12-12
  • oracle鎖表該如何解決

    oracle鎖表該如何解決

    這篇文章主要給大家介紹了關(guān)于oracle鎖表如何解決的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Oracle中時(shí)間日期轉(zhuǎn)化函數(shù)to_date和to_char的具體使用

    Oracle中時(shí)間日期轉(zhuǎn)化函數(shù)to_date和to_char的具體使用

    時(shí)間日期轉(zhuǎn)化函數(shù)在工作中經(jīng)??梢允褂玫牡剑疚闹饕榻B了Oracle中時(shí)間日期轉(zhuǎn)化函數(shù)to_date和to_char的具體使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-05-05
  • oracle 11g的警告日志和監(jiān)聽(tīng)日志的刪除方法

    oracle 11g的警告日志和監(jiān)聽(tīng)日志的刪除方法

    這篇文章主要介紹了oracle 11g的警告日志和監(jiān)聽(tīng)日志的刪除方法,需要的朋友可以參考下
    2014-07-07
  • oracle中的procedure編寫(xiě)和使用詳解

    oracle中的procedure編寫(xiě)和使用詳解

    這篇文章主要介紹了oracle中的procedure編寫(xiě)和使用詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • Oracle開(kāi)發(fā)之分析函數(shù)簡(jiǎn)介Over用法

    Oracle開(kāi)發(fā)之分析函數(shù)簡(jiǎn)介Over用法

    本文主要是對(duì)Oracle分析函數(shù)概念的簡(jiǎn)單介紹,同時(shí)講解了Over函數(shù)的用法,希望對(duì)大家學(xué)習(xí)分析函數(shù)有所幫助。
    2016-05-05
  • group by,having,order by的用法詳解

    group by,having,order by的用法詳解

    如果一個(gè)查詢(xún)中使用了分組函數(shù),任何不在分組函數(shù)中的列或表達(dá)式必須要在group by中,下面為大家簡(jiǎn)要介紹下group by,having,order by的用法
    2013-09-09

最新評(píng)論