91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL插入速度是多少

發布時間:2021-12-04 14:06:42 來源:億速云 閱讀:548 作者:iii 欄目:數據庫

這篇文章主要介紹“MySQL插入速度是多少”,在日常操作中,相信很多人在MySQL插入速度是多少問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MySQL插入速度是多少”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

寫入速度

  • MySQL每秒可以插入50w條記錄嗎?

  • 帶著疑問,我們一起看看mysql每秒可以插入多少條記錄?

  • 要回答這個問題,首先要考慮影響mysql插入速度的因素有哪些?

硬盤的速度,網卡的速度,寫入行的數據量,數據在硬盤中的存放位置等等因素。

簡單的數據,插入速度肯定快,復雜的插入肯定慢。

所以單純這個問題不好回答,最好的辦法是進行壓力測試,最后求一個平均值。

一 測試環境:

MySQL表結構

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硬盤

二. 開始測試

說明:單機測試,不涉及網卡,網絡傳輸的影響

測試程序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.無任何索引,單進程

start write,time is 1593338798 write end, time is 50

耗時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 ,所以索引會導致插入變慢,因為要更新索引

MySQL插入速度是多少
負載

3. 多進程測試

用go寫了一個簡單的多進程執行程序

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(); }
MySQL插入速度是多少
4進程負載

結果:

耗時115s ,插入速度平均3.4w/s

MySQL鎖表狀態

MySQL插入速度是多少
mysql status

10進程一起執行

MySQL插入速度是多少
10進程

耗時5&lsquo;10“ ,插入速度大概3.2w/s

MySQL鎖表狀態

MySQL插入速度是多少
MySQL status

到此,關于“MySQL插入速度是多少”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鹤岗市| 灵宝市| 于都县| 阳山县| 永平县| 彭水| 曲水县| 汉寿县| 临颍县| 二连浩特市| 晋城| 德保县| 丰原市| 广宁县| 惠安县| 宜君县| 新绛县| 志丹县| 穆棱市| 景德镇市| 千阳县| 建湖县| 永城市| 通许县| 利川市| 新兴县| 武陟县| 富裕县| 长乐市| 汾西县| 隆尧县| 宁南县| 普陀区| 长阳| 灵川县| 海南省| 辽宁省| 渭南市| 搜索| 广饶县| 石棉县|