婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Mysql中幾種插入效率的實(shí)例對(duì)比

Mysql中幾種插入效率的實(shí)例對(duì)比

熱門(mén)標(biāo)簽:電銷(xiāo)機(jī)器人說(shuō)明書(shū) 安國(guó)在哪里辦理400電話(huà) 智能電銷(xiāo)機(jī)器人靠譜么 長(zhǎng)安區(qū)違法建房地圖標(biāo)注 地圖標(biāo)注培訓(xùn) 手機(jī)用地圖標(biāo)注工具 南宋地圖標(biāo)注黃河華山 昆明智能外呼系統(tǒng)中心 電銷(xiāo)機(jī)器人公眾號(hào)推送

前言

最近因?yàn)楣ぷ鞯男枰贛ysql里插入大量的數(shù)據(jù)大約1000w,目測(cè)會(huì)比較耗時(shí)。所以現(xiàn)在就像測(cè)試一下到底用什么插入數(shù)據(jù)的方法比較快捷高效。

下面就針對(duì)每一種方法分別測(cè)試不同數(shù)據(jù)量下的插入效率。

測(cè)試數(shù)據(jù)庫(kù)的基本與操作如下:

mysql> create database test;
Query OK, 1 row affected (0.02 sec)
mysql> use test;
Database changed
mysql> create table mytable(id int primary key auto_increment ,value varchar(50));
Query OK, 0 rows affected (0.35 sec)
mysql> desc mytable;
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra  |
+-------+-------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| value | varchar(50) | YES | | NULL |  |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.02 sec)

方便測(cè)試,這里建了一個(gè)表,兩個(gè)字段,一個(gè)是自增的id,另一個(gè)是字符串表示內(nèi)容。

測(cè)試時(shí)每次實(shí)驗(yàn)結(jié)束都要mysql> truncate mytable,來(lái)清空已存在的表。

方法一:逐條插入

測(cè)試代碼:(中間有1000條insert語(yǔ)句,用vim復(fù)制粘貼比較方便,寫(xiě)完后保存到a.sql,然后在mysql提示符中輸入source a.sql)

set @start=(select current_timestamp(6));
insert into mytable values(null,"value");
......
insert into mytable values(null,"value");
set @end=(select current_timestamp(6));
select @start;
select @end;

輸出結(jié)果:

Query OK, 1 row affected (0.03 sec)
......
Query OK, 1 row affected (0.03 sec)
Query OK, 0 rows affected (0.00 sec)
+----------------------------+
| @start   |
+----------------------------+
| 2016-05-05 23:06:51.267029 |
+----------------------------+
1 row in set (0.00 sec)
+----------------------------+
| @end   |
+----------------------------+
| 2016-05-05 23:07:22.831889 |
+----------------------------+
1 row in set (0.00 sec)

總共耗時(shí)31.56486s,事實(shí)上幾乎每條語(yǔ)句花的時(shí)間是差不多的,基本就是30ms。

這樣子1000w的數(shù)據(jù)就得花87h。

至于更大的數(shù)據(jù)量也就不試了,這種方法肯定不可取。

方法二:基于事務(wù)的批量插入

實(shí)際上就是把這么多的查詢(xún)放在一個(gè)事務(wù)中。事實(shí)上方法一中沒(méi)一條語(yǔ)句都開(kāi)了一個(gè)事務(wù),因此才會(huì)特別慢。

測(cè)試代碼:(與方法一基本類(lèi)似,主要添加兩行,由于比較快,這里測(cè)試了多種數(shù)據(jù)量)

set @start=(select current_timestamp(6));
start transaction;
insert into mytable values(null,"value");
......
insert into mytable values(null,"value");
commit;
set @end=(select current_timestamp(6));
select @start;
select @end;

測(cè)試結(jié)果:

數(shù)據(jù)量 時(shí)間(s)
1k  0.1458
1w  1.0793
10w 5.546006
100w 38.930997

看出來(lái)基本是對(duì)數(shù)時(shí)間,效率還是比較高的。

方法三:?jiǎn)螚l語(yǔ)句一次插入多組數(shù)據(jù)

就是一條insert一次插入多個(gè)value。

測(cè)試代碼:

insert into mytable values (null,"value"),
    (null,"value"),
    ......
    (null,"value");

測(cè)試結(jié)果:

數(shù)據(jù)量 時(shí)間(s)
1k  0.15
1w  0.80
10w 2.14
100w *

看上去也是對(duì)數(shù)時(shí)間,而且比方法二要稍微快一點(diǎn)。不過(guò)問(wèn)題在于單次SQL語(yǔ)句是有緩沖區(qū)大小限制的,雖然可以修改配置讓他變大,但也不能太大。所以在插入大批量的數(shù)據(jù)時(shí)也用不了。

方法四:導(dǎo)入數(shù)據(jù)文件

將數(shù)數(shù)據(jù)寫(xiě)成數(shù)據(jù)文件直接導(dǎo)入(參照上一節(jié))。

數(shù)據(jù)文件(a.dat):

null value
null value
.....
null value
null value

測(cè)試代碼:

mysql> load data local infile "a.dat" into table mytable;

測(cè)試結(jié)果:

數(shù)據(jù)量 時(shí)間(s)
1k  0.13
1w  0.75
10w 1.97
100w 6.75
1000w 58.18

時(shí)間最快,就是他了。。。。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • C++操作MySQL大量數(shù)據(jù)插入效率低下的解決方法
  • Java使用JDBC向MySQL數(shù)據(jù)庫(kù)批次插入10W條數(shù)據(jù)(測(cè)試效率)
  • MySql批量插入優(yōu)化Sql執(zhí)行效率實(shí)例詳解
  • mysql中迅速插入百萬(wàn)條測(cè)試數(shù)據(jù)的方法
  • 用一條mysql語(yǔ)句插入多條數(shù)據(jù)
  • MYSQL批量插入數(shù)據(jù)的實(shí)現(xiàn)代碼
  • mysql數(shù)據(jù)庫(kù)插入速度和讀取速度的調(diào)整記錄
  • MySql避免重復(fù)插入記錄的幾種方法

標(biāo)簽:武漢 南昌 潛江 江門(mén) 合肥 吉安 長(zhǎng)沙 東莞

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql中幾種插入效率的實(shí)例對(duì)比》,本文關(guān)鍵詞  Mysql,中,幾種,插入,效率,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql中幾種插入效率的實(shí)例對(duì)比》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Mysql中幾種插入效率的實(shí)例對(duì)比的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 崇礼县| 武夷山市| 英吉沙县| 潮安县| 陆川县| 青冈县| 桐乡市| 广德县| 洪雅县| 平江县| 乐业县| 洪泽县| 安多县| 油尖旺区| 安平县| 和平区| 徐水县| 卢氏县| 南通市| 军事| 大渡口区| 永德县| 邵阳市| 卓尼县| 合作市| 嵩明县| 东城区| 泾阳县| 峨眉山市| 班戈县| 荥阳市| 巩留县| 车致| 高要市| 宁波市| 华安县| 改则县| 沙河市| 望奎县| 六安市| 旬阳县|