0

我的 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 table type possible_keys key key_len ref rows Extra

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

1 SIMPLE re ALL 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 SIMPLE s eq_ref PRIMARY PRIMARY 4 web106-prestwick.ua.staff_id 1

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

4

2 回答 2

1

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

于 2012-07-02T16:09:28.163 回答
0

根据您使用的数据库,优化可能更快,也可能不使用子查询。

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

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

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

于 2012-07-02T15:28:58.443 回答