您好,登錄后才能下訂單哦!
這篇文章主要介紹“MySQL插入速度是多少”,在日常操作中,相信很多人在MySQL插入速度是多少問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”MySQL插入速度是多少”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
寫(xiě)入速度
MySQL每秒可以插入50w條記錄嗎?
帶著疑問(wèn),我們一起看看mysql每秒可以插入多少條記錄?
要回答這個(gè)問(wèn)題,首先要考慮影響mysql插入速度的因素有哪些?
硬盤(pán)的速度,網(wǎng)卡的速度,寫(xiě)入行的數(shù)據(jù)量,數(shù)據(jù)在硬盤(pán)中的存放位置等等因素。
簡(jiǎn)單的數(shù)據(jù),插入速度肯定快,復(fù)雜的插入肯定慢。
所以單純這個(gè)問(wèn)題不好回答,最好的辦法是進(jìn)行壓力測(cè)試,最后求一個(gè)平均值。
一 測(cè)試環(huán)境:
MySQL表結(jié)構(gòu)
CREATE TABLE `user_10w` ( `id` int(10) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `mobile` varchar(11) DEFAULT NULL, `add_time` int(11) DEFAULT NULL, `groupid` tinyint(1) DEFAULT NULL, `login_time` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=4730016 DEFAULT CHARSET=utf8mb4
電腦配置
4核 Intel(R) Core(TM) i3-8100 CPU @ 3.60GHz
ssd 120G硬盤(pán)
二. 開(kāi)始測(cè)試
說(shuō)明:?jiǎn)螜C(jī)測(cè)試,不涉及網(wǎng)卡,網(wǎng)絡(luò)傳輸?shù)挠绊?/p>
測(cè)試程序php pdo
include_once("tool.php"); $dsn = 'mysql:dbname=demo;host=127.0.0.1'; $user = 'root'; $pass = 'root'; try{ $hand = new PDO($dsn, $user, $pass); }catch(PDOException $e){ echo 'Connection failed: ' . $e->getMessage(); } $query = $hand->prepare("insert into user_10w(name,mobile,add_time,groupid,last_login_time) values(?,?,?,?,?)"); $n=0; $count = 1000000; //每次插入100w $t = time(); echo 'start write,time is '. $t. "\n"; while(true){ $n++; $name = Tool::getRandomStr(5); $mobile = Tool::getRandNum(9); $group = Tool::getRandNum(1); $rs = $query->execute([$name,'13'.$mobile,time(),$group,time()]); if($n>$count)break; } echo 'write end, time is '. (time()-$t) . "\n";
1.無(wú)任何索引,單進(jìn)程
start write,time is 1593338798 write end, time is 50
耗時(shí)50s, 平均2w/秒
2. 給name添加普通索引
write end, time is 60 root@test:/data/php# php7 pdo.php start write,time is 1593393695 write end, time is 61
大概慢了10s ,所以索引會(huì)導(dǎo)致插入變慢,因?yàn)橐滤饕?/p>
3. 多進(jìn)程測(cè)試
用go寫(xiě)了一個(gè)簡(jiǎn)單的多進(jìn)程執(zhí)行程序
package main import( "os/exec" "sync" ) var wg sync.WaitGroup func testRun(wg *sync.WaitGroup){ c := exec.Command("php7", "./pdo.php") c.Run() wg.Done() } func main(){ var n int = 10 wg.Add(n) for i:=0;i<n;i++{ go testRun(&wg) } wg.Wait(); }
結(jié)果:
耗時(shí)115s ,插入速度平均3.4w/s
MySQL鎖表狀態(tài)
10進(jìn)程一起執(zhí)行
耗時(shí)5‘10“ ,插入速度大概3.2w/s
MySQL鎖表狀態(tài)
到此,關(guān)于“MySQL插入速度是多少”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。