源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MySQL中distinct与group by之间的性能进行比较

  • 时间:2020-05-31 11:31 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MySQL中distinct与group by之间的性能进行比较
最近在网上看到了一些测试,感觉不是很准确,今天亲自测试了一番。得出了结论,测试过程在个人计算机上,可能不够全面,仅供参考。 [b]测试过程:[/b] 准备一张测试表 
CREATE TABLE `test_test` (
  `id` int(11) NOT NULL auto_increment,
  `num` int(11) NOT NULL default '0',
  PRIMARY KEY (`id`)
  ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
建个储存过程向表中插入10W条数据    
 create procedure p_test(pa int(11)) 
  begin 
  
  declare max_num int(11) default 100000; 
  declare i int default 0; 
  declare rand_num int; 
  
  select count(id) into max_num from test_test; 
  
  while i < pa do 
    if max_num < 100000 then 
      select cast(rand()*100 as unsigned) into rand_num; 
      insert into test_test(num)values(rand_num); 
    end if; 
    set i = i +1; 
  end while; 
  end
调用存储过程插入数据
call p_test(100000);
开始测试:(不加索引)
 select distinct num from test_test; 
 select num from test_test group by num; 
  
 [SQL] select distinct num from test_test;
 受影响的行: 0
 时间: 0.078ms
  
 [SQL] 
 select num from test_test group by num;
 受影响的行: 0
 时间: 0.031ms
[b][/b] [b]二、num字段上创建索引 [/b]
ALTER TABLE `test_test` ADD INDEX `num_index` (`num`) ;
再次查询   
 select distinct num from test_test; 
 select num from test_test group by num; 
 [SQL] select distinct num from test_test;
 受影响的行: 0
 时间: 0.000ms
  
 [SQL] 
 select num from test_test group by num;
 受影响的行: 0
 时间: 0.000ms
[img]http://files.jb51.net/file_images/article/201511/2015119103523281.jpg?2015109103531[/img] 这时候我们发现时间太小了 0.000秒都无法精确了。 我们转到命令行下测试
 mysql> set profiling=1;
 mysql> select distinct(num) from test_test; 
 mysql> select num from test_test group by num;
 mysql> show profiles;
 +----------+------------+----------------------------------------+
 | Query_ID | Duration | Query         |
 +----------+------------+----------------------------------------+
 |  1 | 0.00072550 | select distinct(num) from test_test |
 |  2 | 0.00071650 | select num from test_test group by num |
 +----------+------------+----------------------------------------+
[b][/b] [b]分析:[/b] 加了索引之后[b] distinct 比没加索引的distinct 快了107倍。 [/b]加了索引之后[b] group by 比没加索引的group by 快了43倍。 [/b]再来对比 :[b]distinct 和group by 不管是加不加索引group by 都比distinct 快。[/b] 因此使用的时候建议选 [b]group by。[/b] 以上就是在MySQL中distinct与group by之间的性能进行比较的,通过以上比较是不是对distinct和group by有了更深入的了解,希望对大家的学习有所帮助。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部