gpt4 book ai didi

php - MYSQL查询的问题(效率)

转载 作者:行者123 更新时间:2023-11-29 14:24:14 25 4
gpt4 key购买 nike

我的 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 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,这是我的外键,它们设置不正确。问题已解决

最佳答案

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

关于php - MYSQL查询的问题(效率),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11296143/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com