<bdo id='EJATK'></bdo><ul id='EJATK'></ul>

<tfoot id='EJATK'></tfoot>
    <i id='EJATK'><tr id='EJATK'><dt id='EJATK'><q id='EJATK'><span id='EJATK'><b id='EJATK'><form id='EJATK'><ins id='EJATK'></ins><ul id='EJATK'></ul><sub id='EJATK'></sub></form><legend id='EJATK'></legend><bdo id='EJATK'><pre id='EJATK'><center id='EJATK'></center></pre></bdo></b><th id='EJATK'></th></span></q></dt></tr></i><div id='EJATK'><tfoot id='EJATK'></tfoot><dl id='EJATK'><fieldset id='EJATK'></fieldset></dl></div>

    1. <small id='EJATK'></small><noframes id='EJATK'>

        <legend id='EJATK'><style id='EJATK'><dir id='EJATK'><q id='EJATK'></q></dir></style></legend>

        使用索引,使用临时,使用文件排序 - 如何解决这个问题?

        Using index, using temporary, using filesort - how to fix this?(使用索引,使用临时,使用文件排序 - 如何解决这个问题?)

            <tfoot id='L2HqF'></tfoot>
          • <small id='L2HqF'></small><noframes id='L2HqF'>

            <legend id='L2HqF'><style id='L2HqF'><dir id='L2HqF'><q id='L2HqF'></q></dir></style></legend>

              • <bdo id='L2HqF'></bdo><ul id='L2HqF'></ul>
                  <tbody id='L2HqF'></tbody>
                <i id='L2HqF'><tr id='L2HqF'><dt id='L2HqF'><q id='L2HqF'><span id='L2HqF'><b id='L2HqF'><form id='L2HqF'><ins id='L2HqF'></ins><ul id='L2HqF'></ul><sub id='L2HqF'></sub></form><legend id='L2HqF'></legend><bdo id='L2HqF'><pre id='L2HqF'><center id='L2HqF'></center></pre></bdo></b><th id='L2HqF'></th></span></q></dt></tr></i><div id='L2HqF'><tfoot id='L2HqF'></tfoot><dl id='L2HqF'><fieldset id='L2HqF'></fieldset></dl></div>
                  本文介绍了使用索引,使用临时,使用文件排序 - 如何解决这个问题?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在开发一个事件跟踪系统,该系统使用少量查找表和主日志记录表.在我正在编写的报告中,可以选择一个对象来查看统计信息.界面按重要性递减的顺序显示所有对象(即点击数).

                  I'm working on a event tracking system which uses a handful of lookup tables as well as the primary logging table. In a report I'm writing, an object can be selected to view statistics against. The interface shows all objects in order of decreasing importance (ie, hits).

                  这两个表的架构(略有删减,但你明白了要点):

                  The schema for the two tables (slightly trimmed down, but you get the gist):

                  CREATE TABLE IF NOT EXISTS `event_log` (
                    `event_id` int(11) NOT NULL AUTO_INCREMENT,
                    `user_id` int(5) DEFAULT NULL,
                    `object_id` int(5) DEFAULT NULL,
                    `event_date` datetime DEFAULT NULL,
                    PRIMARY KEY (`event_id`),
                    KEY `user_id` (`user_id`),
                    KEY `object_id` (`object_id`)
                  );
                  
                  CREATE TABLE IF NOT EXISTS `lookup_event_objects` (
                    `object_id` int(11) NOT NULL AUTO_INCREMENT,
                    `object_desc` varchar(255) NOT NULL,
                    PRIMARY KEY (`object_id`)
                  );
                  

                  我遇到的问题如下.它适用于我的约 100 个条目的表格,但 EXPLAIN 让我有点担心.

                  The query I'm having trouble with is below. It works fine with my table of ~100 entries, but the EXPLAIN worries me a little.

                      explain SELECT 
                              el.object_id, 
                              leo.object_desc, 
                              COUNT(el.object_id) as count_rows
                          FROM 
                              event_log el 
                              LEFT JOIN lookup_event_objects leo ON leo.object_id = el.object_id
                          GROUP BY 
                              el.object_id
                          ORDER BY 
                              count_rows DESC,
                              leo.object_desc ASC
                  

                  返回:使用索引;使用临时;使用文件排序

                  那么——我的模式和/或 MySQL 的查询有什么问题,可以依靠 temporaryfilesort?或者它是否像使用 ORDER BY 一样优化?

                  So -- what's wrong with my schema and/or query for MySQL to fall back on temporary and filesort? Or is it as optimized as it can get using ORDER BY?

                  推荐答案

                  好吧,文档 给出了出现使用临时"的确切原因:

                  Well, the doc gives the exact reasons when "Using temporary" will appear:

                  可以在以下条件下创建临时表:

                  Temporary tables can be created under conditions such as these:

                  如果有一个 ORDER BY 子句和一个不同的 GROUP BY 子句,或者如果ORDER BY 或 GROUP BY 包含表中的列,而不是加入队列中的第一个表,创建一个临时表.

                  If there is an ORDER BY clause and a different GROUP BY clause, or if the ORDER BY or GROUP BY contains columns from tables other than the first table in the join queue, a temporary table is created.

                  DISTINCT 结合 ORDER BY 可能需要临时表.

                  DISTINCT combined with ORDER BY may require a temporary table.

                  如果使用 SQL_SMALL_RESULT 选项,MySQL 使用内存中临时表,除非查询还包含元素(描述稍后)需要磁盘存储.

                  If you use the SQL_SMALL_RESULT option, MySQL uses an in-memory temporary table, unless the query also contains elements (described later) that require on-disk storage.

                  快速扫描显示您患有 #1.

                  A quick scan shows that you suffer from #1.

                  还有 这个博客 从 2009 年开始说使用文件排序"意味着不能使用索引执行排序.由于您是按计算域进行排序,因此也是如此.

                  And this blog from 2009 says that "using filesort" means that the sort can't be performed with an index. Since you're ordering by a computed field, that's going to be true, too.

                  所以,这就是错误".

                  这篇关于使用索引,使用临时,使用文件排序 - 如何解决这个问题?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Bogus foreign key constraint fail(虚假外键约束失败)
                  how to get last insert id after insert query in codeigniter active record(如何在codeigniter活动记录中插入查询后获取最后一个插入ID)
                  Force InnoDB to recheck foreign keys on a table/tables?(强制 InnoDB 重新检查表/表上的外键?)
                  How to auto generate migrations with Sequelize CLI from Sequelize models?(如何使用 Sequelize CLI 从 Sequelize 模型自动生成迁移?)
                  Clear MySQL query cache without restarting server(无需重启服务器即可清除 MySQL 查询缓存)
                  ALTER TABLE to add a composite primary key(ALTER TABLE 添加复合主键)
                  <tfoot id='9qvgo'></tfoot>

                • <i id='9qvgo'><tr id='9qvgo'><dt id='9qvgo'><q id='9qvgo'><span id='9qvgo'><b id='9qvgo'><form id='9qvgo'><ins id='9qvgo'></ins><ul id='9qvgo'></ul><sub id='9qvgo'></sub></form><legend id='9qvgo'></legend><bdo id='9qvgo'><pre id='9qvgo'><center id='9qvgo'></center></pre></bdo></b><th id='9qvgo'></th></span></q></dt></tr></i><div id='9qvgo'><tfoot id='9qvgo'></tfoot><dl id='9qvgo'><fieldset id='9qvgo'></fieldset></dl></div>

                • <legend id='9qvgo'><style id='9qvgo'><dir id='9qvgo'><q id='9qvgo'></q></dir></style></legend>
                    <bdo id='9qvgo'></bdo><ul id='9qvgo'></ul>

                    <small id='9qvgo'></small><noframes id='9qvgo'>

                            <tbody id='9qvgo'></tbody>