Mysql入门设置MySQL中的数据类型来优化运行速度的实例
《Mysql入门设置MySQL中的数据类型来优化运行速度的实例》要点: MYSQL实例本日看了一个优化案例觉的挺有代表性,这里记录下来做一个标记,来纪念一下随便的字段定义的问题. MYSQL实例回忆一下,在表的设计中很多人习惯的把表的结构设计成Varchar(64),Varchar(255)之类的,虽然大多数情况只存了5-15个字节.那么我看一下下面这个案例. MYSQL实例
SELECT SQL_NO_CACHE channel,COUNT(channel) AS visitors FROM xxx_sources WHERE client_id = 1301 GROUP BY client_id,channel;
MYSQL实例该表(client_id,channel)是一个组合索引. MYSQL实例
mysql> explain SELECT SQL_NO_CACHE channel,channel;
+----+-------------+-------------+-------+--------------------+--------------------+---------+------+----------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------------+-------+--------------------+--------------------+---------+------+----------+--------------------------+
| 1 | SIMPLE | xxx_sources | index | idx_client_channel | idx_client_channel | 1032 | NULL | 20207319 | Using where; Using index |
+----+-------------+-------------+-------+--------------------+--------------------+---------+------+----------+--------------------------+
1 row in set (0.00 sec)
MYSQL实例看一下实际执行: MYSQL实例
mysql> SELECT SQL_NO_CACHE channel,channel;
+---------+----------+
| channel | visitors |
+---------+----------+
| NULL | 0 |
+---------+----------+
1 row in set (11.69 sec)
MYSQL实例实际执行的情况非常的糟糕.传通的想法,这个执行从索引上执行计划上看非常完美了,好象和MySQL没什么关系了. 在去看一下表的设计会发现client_id也是设计成了 MYSQL实例
mysql> explain SELECT SQL_NO_CACHE channel,COUNT(channel) AS visitors FROM xxx_sources WHERE client_id = '1301' GROUP BY client_id,channel;
+----+-------------+-------------+------+--------------------+--------------------+---------+-------+--------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------------+------+--------------------+--------------------+---------+-------+--------+--------------------------+
| 1 | SIMPLE | xxx_sources | ref | idx_client_channel | idx_client_channel | 258 | const | 457184 | Using where; Using index |
+----+-------------+-------------+------+--------------------+--------------------+---------+-------+--------+--------------------------+
1 row in set (0.00 sec)
MYSQL实例从执行计划上来看,差不多,但实际差多了.具体上来看key_len从1032降到了258,执行计划变成了const基于等于的查找,行数从本来千万级到了十万级了.不算也能明白IO MYSQL实例? MYSQL实例
mysql> SELECT SQL_NO_CACHE channel,channel;
+---------+----------+
| channel | visitors |
+---------+----------+
| NULL | 0 |
+---------+----------+
1 row in set (0.25 sec)
MYSQL实例哇,从11.69秒变成了0.25秒,这是什么概念,优化了多少倍,算一下吧. MYSQL实例看到这里在想什么呢,记住这个案例,嗯,不错,以后还可以加引号优化一下.那为什么不问一下,能不能在优化了,为什么会这样呢? MYSQL实例从这个案例上,我们需要注意什么呢? 《Mysql入门设置MySQL中的数据类型来优化运行速度的实例》是否对您有启发,欢迎查看更多与《Mysql入门设置MySQL中的数据类型来优化运行速度的实例》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |