电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

MySQL去重該使用distinct還是group by?

瀏覽:11日期:2023-10-15 09:04:48

前言

關于group by 與distinct 性能對比:網上結論如下,不走索引少量數據distinct性能更好,大數據量group by 性能好,走索引group by性能好。走索引時分組種類少distinct快。關于網上的結論做一次驗證。

準備階段屏蔽查詢緩存

查看MySQL中是否設置了查詢緩存。為了不影響測試結果,需要關閉查詢緩存。

show variables like ’%query_cache%’;

MySQL去重該使用distinct還是group by?

查看是否開啟查詢緩存決定于query_cache_type和query_cache_size。

方法一:關閉查詢緩存需要找到my.ini,修改query_cache_type需要修改C:ProgramDataMySQLMySQL Server 5.7my.ini配置文件,修改query_cache_type=0或2。 方法二:設置query_cache_size為0,執行以下語句。

set global query_cache_size = 0;

方法三:如果你不想關閉查詢緩存,也可以在使用RESET QUERY CACHE。

現在測試環境中query_cache_type=2代表按需進行查詢緩存,默認的查詢方式是不會進行緩存,如需緩存則需要在查詢語句中加上sql_cache。

數據準備

t0表存放10W少量種類少的數據

drop table if exists t0;create table t0(id bigint primary key auto_increment,a varchar(255) not null) engine=InnoDB default charset=utf8mb4 collate=utf8mb4_bin;12345drop procedure insert_t0_simple_category_data_sp;delimiter //create procedure insert_t0_simple_category_data_sp(IN num int)beginset @i = 0;while @i < num doinsert into t0(a) value(truncate(@i/1000, 0)); set @i = @i + 1;end while;end//call insert_t0_simple_category_data_sp(100000);

t1表存放1W少量種類多的數據

drop table if exists t1;create table t1 like t0;12drop procedure insert_t1_complex_category_data_sp;delimiter //create procedure insert_t1_complex_category_data_sp(IN num int)beginset @i = 0;while @i < num doinsert into t1(a) value(truncate(@i/10, 0)); set @i = @i + 1;end while;end//call insert_t1_complex_category_data_sp(10000);

t2表存放500W大量種類多的數據

drop table if exists t2;create table t2 like t1;12drop procedure insert_t2_complex_category_data_sp;delimiter //create procedure insert_t2_complex_category_data_sp(IN num int)beginset @i = 0;while @i < num doinsert into t1(a) value(truncate(@i/10, 0)); set @i = @i + 1;end while;end//call insert_t2_complex_category_data_sp(5000000);

測試階段

驗證少量種類少數據

未加索引

set profiling = 1;select distinct a from t0;show profiles;select a from t0 group by a;show profiles;alter table t0 add index `a_t0_index`(a);

MySQL去重該使用distinct還是group by?

由此可見:少量種類少數據下,未加索引,distinct和group by性能相差無幾。

加索引

alter table t0 add index `a_t0_index`(a);

執行上述類似查詢后

MySQL去重該使用distinct還是group by?

由此可見:少量種類少數據下,加索引,distinct和group by性能相差無幾。

驗證少量種類多數據未加索引

執行上述類似未加索引查詢后

MySQL去重該使用distinct還是group by?

由此可見:少量種類多數據下,未加索引,distinct比group by性能略高,差距并不大。

加索引

alter table t1 add index `a_t1_index`(a);

執行類似未加索引查詢后

MySQL去重該使用distinct還是group by?

由此可見:少量種類多數據下,加索引,distinct和group by性能相差無幾。

驗證大量種類多數據

未加索引

SELECT count(1) FROM t2;

MySQL去重該使用distinct還是group by?

執行上述類似未加索引查詢后

MySQL去重該使用distinct還是group by?

由此可見:大量種類多數據下,未加索引,distinct比group by性能高。

加索引

alter table t2 add index `a_t2_index`(a);

執行上述類似加索引查詢后

MySQL去重該使用distinct還是group by?

由此可見:大量種類多數據下,加索引,distinct和group by性能相差無幾。

總結性能比少量種類少少量種類多大量種類多未加索引相差無幾distinct略優distinct更優加索引相差無幾相差無幾相差無幾

去重場景下,未加索引時,更偏向于使用distinct,而加索引時,distinct和group by兩者都可以使用。

總結

到此這篇關于MySQL去重該使用distinct還是group by?的文章就介紹到這了,更多相關mysql 去重distinct group by內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 耐酸碱胶管_耐腐蚀软管总成_化学品输送软管_漯河利通液压科技耐油耐磨喷砂软管|耐腐蚀化学软管 | 小型数控车床-数控车床厂家-双头数控车床 | 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 海峰资讯 - 专注装饰公司营销型网站建设和网络营销培训 | 吉林污水处理公司,长春工业污水处理设备,净水设备-长春易洁环保科技有限公司 | 消泡剂-水处理消泡剂-涂料消泡剂-切削液消泡剂价格-东莞德丰消泡剂厂家 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 板材品牌-中国胶合板行业十大品牌-环保板材-上海声达板材 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 陕西安玻璃自动感应门-自动重叠门-磁悬浮平开门厂家【捷申达门业】 | 股指期货-期货开户-交易手续费佣金加1分-保证金低-期货公司排名靠前-万利信息开户 | 德国EA可编程直流电源_电子负载,中国台湾固纬直流电源_交流电源-苏州展文电子科技有限公司 | ?水马注水围挡_塑料注水围挡_防撞桶-常州瑞轩水马注水围挡有限公司 | 识禅_对禅的了解,从这里开始| 桐城新闻网—桐城市融媒体中心主办| 深圳活动策划公司|庆典策划|专业公关活动策划|深圳艺典文化传媒 重庆中专|职高|技校招生-重庆中专招生网 | 地源热泵一体机,地源热泵厂家-淄博汇能环保设备有限公司 | 食安观察网| 英思科GTD-3000EX(美国英思科气体检测仪MX4MX6)百科-北京嘉华众信科技有限公司 | 防爆暖风机_防爆电暖器_防爆电暖风机_防爆电热油汀_南阳市中通智能科技集团有限公司 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 超声波清洗机_细胞破碎仪_实验室超声仪器_恒温水浴-广东洁盟深那仪器 | 吸音板,隔音板,吸音材料,吸音板价格,声学材料 - 佛山诺声吸音板厂家 | 千斤顶,液压千斤顶-力良企业,专业的液压千斤顶制造商,shliliang.com | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 天命文免费算命堂_自助算命_自由算命系统_长文周易 | 六维力传感器_六分量力传感器_模腔压力传感器-南京数智微传感科技有限公司 | PC构件-PC预制构件-构件设计-建筑预制构件-PC构件厂-锦萧新材料科技(浙江)股份有限公司 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | SF6环境监测系统-接地环流在线监测装置-瑟恩实业 | 手术示教系统-数字化手术室系统-林之硕医疗云智能视频平台 | 不锈钢闸阀_球阀_蝶阀_止回阀_调节阀_截止阀-可拉伐阀门(上海)有限公司 | 蓝牙音频分析仪-多功能-四通道-八通道音频分析仪-东莞市奥普新音频技术有限公司 | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 全温恒温摇床-水浴气浴恒温摇床-光照恒温培养摇床-常州金坛精达仪器制造有限公司 | 苗木价格-苗木批发-沭阳苗木基地-沭阳花木-长之鸿园林苗木场 | 北京浩云律师事务所-法律顾问_企业法务_律师顾问_公司顾问 | 流变仪-热分析联用仪-热膨胀仪厂家-耐驰科学仪器商贸 | 求是网 - 思想建党 理论强党| 吉祥新世纪铝塑板_生产铝塑板厂家_铝塑板生产厂家_临沂市兴达铝塑装饰材料有限公司 |