繁体   English   中英

MYSQL查询问题(效率)

[英]Problems with MYSQL query (efficiency)

我的Mysql语句遇到真正的问题,我需要将几个表连接在一起,查询它们并按另一个表的平均值进行排序。 这就是我所拥有的...

    SELECT
    ROUND(avg(re.rating), 1)AS avg_rating,
         s.staff_id, s.full_name, s.mobile, s.telephone, s.email, s.drive
    FROM staff s

    INNER JOIN staff_homes sh 
     ON s.staff_id=sh.staff_id
    INNER JOIN staff_positions sp 
     ON s.staff_id=sp.staff_id
    INNER JOIN reliability re 
     ON s.staff_id=re.staff_id
    INNER JOIN availability ua 
     ON s.staff_id=ua.staff_id 

    GROUP BY staff_id
    ORDER BY avg_rating DESC

现在,我相信这是可行的,尽管我收到此错误“ SELECT将检查超过MAX_JOIN_SIZE行;检查您的WHERE并使用SET SQL_BIG_SELECTS = 1或SET SQL_MAX_JOIN_SIZE =#(如果SELECT可以的话)”。

我认为这意味着我有太多的联接,并且因为它是共享托管,所以不允许运行大型查询(我不知道)。

我想知道的是错误的确切含义(我已经用谷歌搜索了,但我不明白答案),以及如何通过使查询效率更高来解决该问题?

任何帮助,将不胜感激。 谢谢

编辑:

我需要连接的原因是,这样我就可以基于像这样的搜索功能查询表...

     SELECT
 ROUND(avg(re.rating), 1)AS avg_rating

 ,  s.staff_id, s.full_name, s.mobile, s.telephone, s.email, s.drive
FROM staff s

 INNER JOIN staff_homes sh 
 ON s.staff_id=sh.staff_id
 INNER JOIN staff_positions sp 
 ON s.staff_id=sp.staff_id
 INNER JOIN reliability re 
 ON s.staff_id=re.staff_id
 INNER JOIN availability ua 
 ON s.staff_id=ua.staff_id

WHERE s.full_name LIKE '%'
AND s.drive = '1'
AND sh.home_id = '3'
AND sh.can_work = '1'
AND sp.position_id = '3'
AND sp.can_work = '1'


GROUP BY staff_id
ORDER BY avg_rating DESC

编辑2

这是我解释的结果。 另外,我对MYSQL不太满意,如何设置外键?

id select_type表的类型possible_keys键key_len参考行额外

1 SIMPLE UA ALL NULL NULL NULL NULL 14使用临时; 使用文件排序

1 SIMPLE RE ALL NULL NULL NULL NULL NULL 50使用where; 使用联接缓冲区

1 SIMPLE sp ALL NULL NULL NULL NULL 84使用where; 使用联接缓冲区

1 SIMPLE sh ALL NULL NULL NULL NULL 126使用where; 使用联接缓冲区

1个简单的eq_ref主数据主数据4 web106-prestwick.ua.staff_id 1

编辑3:谢谢lc,这是我的外键,它们没有正确设置。 问题排序

也许您应该在表上使用更多和/或更好的索引。

根据您正在使用的数据库,子查询的优化可能更快或更慢。

您的查询可能存在2个瓶颈:

  • 尝试删除查询的平均功能。 如果您的查询速度加快,请尝试用子查询替换它,然后看看会发生什么。

  • 多个联接通常会降低性能,除了修改数据库架构之外,您无能为力。 最简单的解决方案是拥有一个可预先计算数据并减少数据库引擎工作量的表。 修改隐含表上的数据时,可以通过触发存储过程来实现此表,也可以从php应用程序中修改表值。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM