成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

MySql學習筆記(六):掃描范圍-創(chuàng)新互聯(lián)

explain的type列表示該條查詢的掃描范圍,一共有七種,效果由上到下排列:

網站建設哪家好,找創(chuàng)新互聯(lián)建站!專注于網頁設計、網站建設、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了撫松免費建站歡迎大家使用!

system>const>eq_ref>ref>range>index>all。

數(shù)據(jù)準備:

CREATE TABLE `t_blog` (   `id` int(11) NOT NULL auto_increment,   `title` varchar(50) default NULL,   `typeId` int(11) default NULL,   PRIMARY KEY  (`id`),   UNIQUE KEY `title_index` (`title`),   KEY `type_index` (`typeId`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 CREATE TABLE `t_type` (   `id` int(11) NOT NULL auto_increment,   `name` varchar(20) default NULL,   PRIMARY KEY  (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8

1、system

該表中只有一行記錄,這種情況在日常開發(fā)中很少見,不多贅述;

2、const

表示通過索引一次就找到了結果,用于掃描主鍵和唯一索引,例如:

mysql> explain select * from t_blog where id = 1; +----+-------------+--------+-------+---------------+---------+---------+-------+------+-------+ | id | select_type | table  | type  | possible_keys | key     | key_len | ref   | rows | Extra | +----+-------------+--------+-------+---------------+---------+---------+-------+------+-------+ |  1 | SIMPLE      | t_blog | const | PRIMARY       | PRIMARY | 4       | const |    1 |       | +----+-------------+--------+-------+---------------+---------+---------+-------+------+-------+ 1 row in set

在where子句中,id為主鍵且值為一個常數(shù),在id索引中只有一條數(shù)據(jù)與之對應。

3、eq_ref

通過主鍵和唯一索引,只有一條數(shù)據(jù)與之匹配,例如:

mysql> explain select b.* from t_blog b left join t_type t on b.typeId = t.id; +----+-------------+-------+--------+---------------+---------+---------+---------------+------+-------------+ | id | select_type | table | type   | possible_keys | key     | key_len | ref           | rows | Extra       | +----+-------------+-------+--------+---------------+---------+---------+---------------+------+-------------+ |  1 | SIMPLE      | b     | ALL    | NULL          | NULL    | NULL    | NULL          |    7 |             | |  1 | SIMPLE      | t     | eq_ref | PRIMARY       | PRIMARY | 4       | blog.b.typeId |    1 | Using index | +----+-------------+-------+--------+---------------+---------+---------+---------------+------+-------------+ 2 rows in set

eq_ref和const都表示在唯一索引或主鍵的作用下,只找到一行與之匹配的數(shù)據(jù)。const表示按主鍵和唯一索引讀取,eq_ref通常體現(xiàn)在連表上,按連表的主鍵和唯一索引讀取。

4、ref

非唯一索引掃描,有多個行與之匹配

mysql> explain select * from t_blog where typeId = 4; +----+-------------+--------+------+---------------+------------+---------+-------+------+-------------+ | id | select_type | table  | type | possible_keys | key        | key_len | ref   | rows | Extra       | +----+-------------+--------+------+---------------+------------+---------+-------+------+-------------+ |  1 | SIMPLE      | t_blog | ref  | type_index    | type_index | 5       | const |    1 | Using where | +----+-------------+--------+------+---------------+------------+---------+-------+------+-------------+ 1 row in set

typeId是表的普通索引,即非唯一索引,與eq_ref大的區(qū)別在于ref表示非唯一索引掃描。

5、range

表示范圍,使用索引選擇行,使用了 > < in beteen等

mysql> EXPLAIN select * from t_blog where id>2; +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ | id | select_type | table  | type  | possible_keys | key     | key_len | ref  | rows | Extra       | +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ |  1 | SIMPLE      | t_blog | range | PRIMARY       | PRIMARY | 4       | NULL |    3 | Using where | +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ 1 row in set

6、index

遍歷索引樹,讀全表

mysql> EXPLAIN select id from t_blog; +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ | id | select_type | table  | type  | possible_keys | key     | key_len | ref  | rows | Extra       | +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ |  1 | SIMPLE      | t_blog | index | NULL          | PRIMARY | 4       | NULL |    7 | Using index | +----+-------------+--------+-------+---------------+---------+---------+------+------+-------------+ 1 row in set

只查詢id,所以只遍歷索引文件即可,不需要從硬盤中讀取,比all快。

7、all

讀全表,不使用任何索引,從硬盤中讀數(shù)據(jù),最慢

mysql> explain  select * from t_blog; +----+-------------+--------+------+---------------+------+---------+------+------+-------+ | id | select_type | table  | type | possible_keys | key  | key_len | ref  | rows | Extra | +----+-------------+--------+------+---------------+------+---------+------+------+-------+ |  1 | SIMPLE      | t_blog | ALL  | NULL          | NULL | NULL    | NULL |    7 |       | +----+-------------+--------+------+---------------+------+---------+------+------+-------+ 1 row in set

*在一般的開發(fā)過程中,達到ref即可

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

文章標題:MySql學習筆記(六):掃描范圍-創(chuàng)新互聯(lián)
標題來源:http://jinyejixie.com/article36/diocsg.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化建站公司、商城網站、品牌網站建設、網站建設App設計

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網站優(yōu)化排名
杂多县| 万载县| 莱芜市| 金门县| 道真| 长治县| 团风县| 兴仁县| 南和县| 康保县| 沙雅县| 团风县| 正蓝旗| 汉源县| 金堂县| 鞍山市| 阜南县| 酒泉市| 滁州市| 隆子县| 扬中市| 惠州市| 农安县| 松潘县| 利辛县| 新邵县| 中方县| 开阳县| 谢通门县| 龙口市| 定结县| 额尔古纳市| 泸西县| 攀枝花市| 连江县| 昆山市| 宝清县| 怀宁县| 平阴县| 延寿县| 喀什市|