我的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没问题”。
我认为这意味着我有太多的连接,因为它是共享主机,它不允许大型查询运行我不知道。
我想知道的是错误的意思(我用Google搜索但我不明白答案)以及如何通过提高查询效率来解决这个问题?
任何帮助将不胜感激。感谢
编辑:
我需要连接的原因是我可以根据搜索功能查询表格......
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 ref rows Extra
1 SIMPLE ua ALL NULL NULL NULL NULL 14使用临时;使用filesort
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,这是我的外键,它们没有正确设置。问题排序
答案 0 :(得分:1)
也许你应该在表格上使用更多和/或更好的索引。
答案 1 :(得分:0)
根据您正在使用的数据库,使用子查询可以更快或不优化。
您的查询可能存在2个瓶颈:
尝试删除查询的平均功能。如果您的查询速度加快,请尝试将其替换为子查询,看看会发生什么。
多个连接通常会降低性能,除了修改数据库模式之外,您无能为力。最简单的解决方案是拥有一个预先计算数据并减少数据库引擎工作的表。使用在隐含表上修改数据时触发的存储过程可以实现此表,或者也可以从php应用程序修改表值。