《Mysql入門Mysql中幾種插入效率的實(shí)例對比》要點(diǎn):
本文介紹了Mysql入門Mysql中幾種插入效率的實(shí)例對比,希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL教程前言
MYSQL教程最近因為工作的需要,要在Mysql里插入大量的數(shù)據(jù)大約1000w,目測會比較耗時.所以現(xiàn)在就像測試一下到底用什么插入數(shù)據(jù)的方法比較快捷高效.
MYSQL教程下面就針對每一種方法分別測試不同數(shù)據(jù)量下的插入效率.
MYSQL教程測試數(shù)據(jù)庫的基本與操作如下:
MYSQL教程
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)
MYSQL教程方便測試,這里建了一個表,兩個字段,一個是自增的id,另一個是字符串表示內(nèi)容.
MYSQL教程測試時每次實(shí)驗結(jié)束都要mysql> truncate mytable
,來清空已存在的表.
MYSQL教程方法一:逐條插入
MYSQL教程測試代碼:(中間有1000條insert語句,用vim復(fù)制粘貼比較方便,寫完后保存到a.sql,然后在mysql提示符中輸入source a.sql)
MYSQL教程
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;
MYSQL教程輸出結(jié)果:
MYSQL教程
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)
MYSQL教程總共耗時31.56486s,事實(shí)上幾乎每條語句花的時間是差不多的,基本就是30ms.
MYSQL教程這樣子1000w的數(shù)據(jù)就得花87h.
MYSQL教程至于更大的數(shù)據(jù)量也就不試了,這種方法肯定不可取.
MYSQL教程方法二:基于事務(wù)的批量插入
MYSQL教程實(shí)際上就是把這么多的查詢放在一個事務(wù)中.事實(shí)上方法一中沒一條語句都開了一個事務(wù),因此才會特別慢.
MYSQL教程測試代碼:(與方法一基本類似,主要添加兩行,由于比較快,這里測試了多種數(shù)據(jù)量)
MYSQL教程
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;
MYSQL教程測試結(jié)果:
MYSQL教程
數(shù)據(jù)量 時間(s)
1k 0.1458
1w 1.0793
10w 5.546006
100w 38.930997
MYSQL教程看出來基本是對數(shù)時間,效率還是比較高的.
MYSQL教程方法三:單條語句一次插入多組數(shù)據(jù)
MYSQL教程就是一條insert一次插入多個value.
MYSQL教程測試代碼:
MYSQL教程
insert into mytable values (null,"value"),
(null,"value"),
......
(null,"value");
MYSQL教程測試結(jié)果:
MYSQL教程
數(shù)據(jù)量 時間(s)
1k 0.15
1w 0.80
10w 2.14
100w *
MYSQL教程看上去也是對數(shù)時間,而且比方法二要稍微快一點(diǎn).不過問題在于單次SQL語句是有緩沖區(qū)大小限制的,雖然可以修改配置讓他變大,但也不能太大.所以在插入大批量的數(shù)據(jù)時也用不了.
MYSQL教程方法四:導(dǎo)入數(shù)據(jù)文件
MYSQL教程將數(shù)數(shù)據(jù)寫成數(shù)據(jù)文件直接導(dǎo)入(參照上一節(jié)).
MYSQL教程數(shù)據(jù)文件(a.dat):
MYSQL教程
null value
null value
.....
null value
null value
MYSQL教程測試代碼:
MYSQL教程
mysql> load data local infile "a.dat" into table mytable;
MYSQL教程測試結(jié)果:
MYSQL教程
數(shù)據(jù)量 時間(s)
1k 0.13
1w 0.75
10w 1.97
100w 6.75
1000w 58.18
MYSQL教程時間最快,就是他了....
MYSQL教程總結(jié)
MYSQL教程以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對維易PHP的支持.
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/5938.html