如何解决使用来自另一个表的子查询从表中删除
Tables 我需要从学生表中删除所有学生的正确答案低于exam_results 表中正确答案的平均百分比。必须使用子查询来完成。
到目前为止我已经尝试过:
DELETE FROM students
WHERE id IN (SELECT student_id FROM exam_results WHERE percentage < AVG(percentage));
返回:ERROR 1111: Invalid use of group function
为什么这是对组功能的无效使用? 我错过了什么或有什么问题?
非常感谢任何帮助!谢谢!
解决方法
您需要按如下方式在 sub-query
中找到学生:
DELETE FROM students
WHERE id IN
(SELECT student_id
FROM exam_results
WHERE percentage < (select AVG(percentage) from exam_results);
您也可以使用 analytical function
但这取决于您的 MySql 版本。所以请标记您正在使用的数据库及其版本。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。