千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > MySQL批量插入數(shù)據(jù)為什么比逐個(gè)插入效率高?

MySQL批量插入數(shù)據(jù)為什么比逐個(gè)插入效率高?

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-11 22:57:36 1697036256

一、MySQL批量插入數(shù)據(jù)為什么比逐個(gè)插入效率高

數(shù)據(jù)庫(kù)的一個(gè)插入動(dòng)作,包含了連接,傳輸,執(zhí)行,提交/回滾 等等的動(dòng)作,在 執(zhí)行的時(shí)候可能還會(huì)遇到鎖表,等待等等,所以,批量插比逐個(gè)插效率高,是大部分情況,而不是絕對(duì)情況。

大部分情況下,批量插和逐個(gè)插,在執(zhí)行層面,耗時(shí)接近;而不用多次連接數(shù)據(jù)庫(kù),在數(shù)據(jù)傳輸層面,也是一次性傳輸效率高(網(wǎng)絡(luò)傳輸和這個(gè)模型類(lèi)似,也有很多前置后置過(guò)程),而提交,也是只發(fā)起了一次,因而顯得效率高。

在特殊情況下,比如插入的數(shù)據(jù)是業(yè)務(wù)表,每行的數(shù)據(jù)量較大,且該表訪問(wèn)頻繁,那么,插入1條的時(shí)候可能不會(huì)鎖表,而插入10000行的時(shí)候,會(huì)遇到鎖表的情況。如果并發(fā)插入,甚至發(fā)生死鎖。這個(gè)時(shí)候,就要根據(jù)經(jīng)驗(yàn)分析,調(diào)整每個(gè)批次的量,以避免影響使用。

舉個(gè)例子:

begin:

insert into ( (‘a(chǎn)’) , (‘b’) …);

commit;

這樣批量提交和

insert into(‘a(chǎn)’) ;

insert into (‘b’);

看上去也不需要多久,你看看非編譯型的語(yǔ)言php,js幾乎都不需要多久,你10w行sql對(duì)應(yīng)其他代碼的parser,你想想一個(gè)10wjs需要編譯很久嗎?也不需要很久。

延伸閱讀:

二、什么是Memory引擎

Memory引擎是Mysql的內(nèi)存引擎,在實(shí)現(xiàn)上,Memory存儲(chǔ)引擎不同于Innodb這種組織索引結(jié)構(gòu)(索引即是數(shù)據(jù),即數(shù)據(jù)存放在主鍵索引上),而是將索引和數(shù)據(jù)分開(kāi)存儲(chǔ)。索引采用Hash的形式,存放主鍵id和指向數(shù)據(jù)的指針,而數(shù)據(jù)則按插入順序存放。我們稱(chēng)這種數(shù)據(jù)組織方式為堆組織方式。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
mysql inner join為什么不走索引?

一、mysql inner join為什么不走索引因?yàn)樗饕膬?yōu)勢(shì)是在大表中過(guò)濾出小的結(jié)果集進(jìn)行聯(lián)接,mysql inner join句根本沒(méi)有任何過(guò)濾條件。另外表很小...詳情>>

2023-10-11 23:07:14
Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比,優(yōu)缺點(diǎn)?

一、Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比兩者的定位不一樣。Geode是分布式內(nèi)存數(shù)據(jù)庫(kù),提供了可配置的一致性保證,能夠保證數(shù)據(jù)不丟失,更...詳情>>

2023-10-11 22:50:49
InnoDB的next-key lock為什么是左開(kāi)右閉的?

一、InnoDB的next-key lock為什么是左開(kāi)右閉的InnoDB的next-key lock本身的設(shè)計(jì)方案就是左開(kāi)右閉的,例如select * from t where c2 = 10 fo詳情>>

2023-10-11 22:48:02
到底哪些APP在用Flutter?

一、滴滴出行滴滴出行是一款出行服務(wù)平臺(tái),提供打車(chē)、順風(fēng)車(chē)、單車(chē)等多種出行方式。在采用Flutter技術(shù)后,滴滴出行成功實(shí)現(xiàn)了Android和iOS平臺(tái)...詳情>>

2023-10-11 22:45:35
web前端和UI前端的區(qū)別?

一、職責(zé)不同Web前端主要負(fù)責(zé)開(kāi)發(fā)網(wǎng)站的前端部分,通過(guò)編寫(xiě)代碼實(shí)現(xiàn)網(wǎng)站的用戶界面和交互功能。而UI前端(也稱(chēng)為UI設(shè)計(jì)師或UI工程師)負(fù)責(zé)設(shè)計(jì)...詳情>>

2023-10-11 22:40:09
快速通道