数据库
首页 > 数据库> > 严重的MySQL性能问题(联接,临时表,文件…)

严重的MySQL性能问题(联接,临时表,文件…)

作者:互联网

我有一张用户表和一张投票表.投票表存储对其他用户的投票.无论好坏,投票表中的一行,都会在两个用户之间的两个方向上存储投票.

现在,问题在于我想列出一些人投票的所有人.

我不是MySQL的专家,但是根据我的想法,由于join语句中的OR条件,它需要查看整个users表(目前44,000行),并创建一个临时表来执行此操作.

目前,bellow查询大约需要两分钟,是的,两分钟即可完成.如果我在join语句中删除OR条件及其后面的所有内容,它会在不到半秒的时间内运行,因为它只需要查看44,000个用户行中的大约17个(解释ftw!).

下面的示例,用户ID是9834,我正在尝试获取他/她自己没有投票,并加入投票的用户的信息到结果.

是否有更好,更快的方法来执行此查询?或者我应该重组表格?我真的希望可以通过修改查询来修复它,因为表中已经有很多用户(44,000)和投票(130,000),我必须迁移它们.

谢谢 :)

SELECT *, votes.id as vote_id 
FROM `votes` 
LEFT JOIN users ON (
  (
    votes.user_id_1 = 9834
    AND
    users.uid = votes.user_id_2
  )
  OR
  (
    votes.user_id_2 = 9834
    AND
    users.uid = votes.user_id_1
  )
)
WHERE (
  (
    votes.user_id_1 = 9834
    AND
    votes.vote_1 = 0
  )
  OR
  (
    votes.user_id_2 = 9834
    AND
    votes.vote_2 = 0
  )
)
ORDER BY votes.updated_at DESC
LIMIT 0, 10

解决方法:

您可以执行UNION of 2查询而不是OR.我知道在至少一个其他DBMS中这个速度快一个数量级的实例,我猜测MySQL的查询优化器可能共享相同的“功能”.

SELECT  whatever
FROM    votes v
        INNER JOIN
                users u
                ON v.user_id_1 = u.uid
WHERE   v.user_id_2 = 9834
AND     v.votes_2 = 0

UNION

SELECT  whatever
FROM    votes v
        INNER JOIN
                users u
                ON v.user_id_2 = u.uid
WHERE   v.user_id_1 = 9834
AND     v.votes_1 = 0

ORDER BY updated_at DESC

标签:performance,mysql,join,database,temp-tables
来源: https://codeday.me/bug/20190827/1743719.html