相关疑难解决方法(0)

使用ORDER BY时查询速度慢

这是查询(最大的表有大约40,000行)

SELECT
  Course.CourseID,
  Course.Description,
  UserCourse.UserID,
  UserCourse.TimeAllowed,
  UserCourse.CreatedOn,
  UserCourse.PassedOn,
  UserCourse.IssuedOn,
  C.LessonCnt
FROM
  UserCourse
INNER JOIN
  Course
USING(CourseID)
INNER JOIN
(
  SELECT CourseID, COUNT(*) AS LessonCnt FROM CourseSection GROUP BY CourseID
) C
USING(CourseID)
WHERE 
  UserCourse.UserID = 8810
Run Code Online (Sandbox Code Playgroud)

如果我运行它,它会很快执行(大约.05秒).它返回13行.

当我ORDER BY在查询末尾添加一个子句(按任何列排序)时,查询大约需要10秒.

我现在在生产中使用这个数据库,一切正常.我所有的其他疑问都很快.

有什么想法可能是什么?我在MySQL的查询浏览器中运行查询,并从命令行运行.这两个地方都很慢了ORDER BY.

编辑: Tolgahan ALBAYRAK解决方案的工作原理,但谁能解释为什么它的工作原理?

mysql sql-order-by

18
推荐指数
2
解决办法
3万
查看次数

我如何在MySQL中请求帮助优化和修复查询?

MySQL问题是StackOverflow上我最喜欢的一些问题.

不幸的是,这样的事情:

SELECT foo, bar, baz, quux, frozzle, lambchops FROM something JOIN somethingelse ON 1=1 JOIN (SELECT * FROM areyouserious) v ON 0=5 WHERE lambchops = 'good';
Run Code Online (Sandbox Code Playgroud)

让我的眼睛流血.

此外,尝试描述您的架构通常如下所示:

我有一个表CrazyTable,其中一个列是一个日期,它有一个主键Foo_Key但我想使用column_bar的子串(在CrazyTable中)加入SOMETABLE,该子串与月亮的相位有关(我存储了它)在moon_phases中作为三次序列化的PHP数组).

这是我问的一个问题的例子,如果我没有按照下面的步骤操作,我将永远不会得到任何人的满意答复:我没有羞耻..

我将在下面回答最能帮助解决问题的方法.什么帮助

mysql optimization

12
推荐指数
1
解决办法
291
查看次数

标签 统计

mysql ×2

optimization ×1

sql-order-by ×1