国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

myisam - 關于mysql的定長表

瀏覽:166日期:2022-06-20 08:05:52

問題描述

首先,問題是定長表的查詢速度為什么會比不定長表會慢有這么一張大的users表,存儲的字段比較多,然后設計成為了主表和副表,使用的存儲引擎都是myisam與前輩聊天,前輩說這種設計需要把主表設計成定長表,這樣在進行數據查詢的時候速度上會更快,因為每個字段的長度是定長的,所以每條記錄的長度也是定長的但是實際上我在用的時候,發現定長表并沒有更快(以下是兩張myisam的表,數據量為140萬+):定長表,以下簡稱a表:

CREATE TABLE `users_myisam_fixed` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `name` char(100) COLLATE utf8_unicode_ci NOT NULL, `email` char(100) COLLATE utf8_unicode_ci NOT NULL, `password` char(60) COLLATE utf8_unicode_ci NOT NULL, `remember_token` char(100) COLLATE utf8_unicode_ci DEFAULT NULL, `age` tinyint(4) NOT NULL, PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=1544258 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

不定長表,以下簡稱b表:

CREATE TABLE `users_myisam` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(100) COLLATE utf8_unicode_ci NOT NULL, `email` varchar(100) COLLATE utf8_unicode_ci NOT NULL, `password` varchar(60) COLLATE utf8_unicode_ci NOT NULL, `remember_token` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL, `age` tinyint(4) NOT NULL, PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=1544258 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

以上,表中都沒有添加索引。在兩個表中分別執行select * from {$tablename} 的時候:a表耗時4.302s,b表耗時3.484s 定長表反而更慢。。在分別執行select * from {$tablename} where name=’may25’,select * from {$tablename} where name like ’a%’ 的時候,還是a表所用時間更長

之前在學習mysql的時候也知道char和varchar是存在查詢上的差距的,但是并沒有實際的嘗試過,誰能給我解釋一下為什么我在嘗試的時候定長表反而會更慢?沒有添加索引的原因?還是什么的別的原因。。。一臉懵逼求大神

問題解答

回答1:

具體底層沒研究過,我猜測應該是定長可以防止在機械硬盤上導致產生大量碎片文件,增加查找時的尋道時間。如果你是ssd的話,這個應該是不存在問題的。

回答2:

你的數據中如果有很多null,那么varchar 所占用的長度會比char少,且在你的myisam表中長度肯定有冗余,那么這個時候varchar所占用的空間會比cahr少,因為varchar是根據實際占用來保存數據的,空間占用越多每次查詢的時候要搜尋的時間也會相應地增加,這就會導致查詢時間上升。

相關文章:
主站蜘蛛池模板: 日韩一级欧美一级毛片在线 | 国产看色免费 | 性做久久久久免费观看 | 免看一级a毛片一片成人不卡 | 夜鲁夜鲁夜鲁在线观看福利 | 日本免费特黄aa毛片 | 精品国产成人a区在线观看 精品国产成人a在线观看 | 久久频这里精品99香蕉久 | 精品国产高清不卡毛片 | 国内精品福利在线视频 | 成人午夜在线观看国产 | 国产精品大片天天看片 | 免费aⅴ片 | 免费国产a理论片 | 欧美成人看片一区二区三区尤物 | 一级一毛片a级毛片欧美 | 亚洲精品高清在线 | 日韩毛片免费在线观看 | 亚洲国产片 | 免费国产黄网站在线观看视频 | 国产美女白丝袜精品_a不卡 | 一级一级特黄女人精品毛片 | 国产真实乱子伦xxxxchina | 一级做性色a爱片久久片 | 一级毛片在线不卡直接观看 | 亚洲影院在线播放 | 成人一级黄色毛片 | 久草资源在线视频 | 九九99香蕉在线视频免费 | 国产高清免费观看 | 正能量www正能量免费网站 | 在线精品一区二区三区 | 久久午夜影院 | a级高清观看视频在线看 | 欧美日韩亚洲第一页 | 亚洲欧美日韩综合久久久久 | 日产一区二区三区四区 | 欧美亚洲日本视频 | 国产欧美日韩一区二区三区在线 | 欧美老头老太做爰xxxx | 欧美另类自拍 |