您的位置:首页技术文章
文章详情页

mysql - 这条sql语句为什么加上where就报错?

【字号: 日期:2022-06-17 09:07:17浏览:14作者:猪猪

问题描述

mysql - 这条sql语句为什么加上where就报错?mysql - 这条sql语句为什么加上where就报错?

这条SQL

SELECT *,SUM(tuanke_time.time) AS total_time FROM `tuanke_time` LEFT JOIN tuanke_student ON tuanke_student.Sid = tuanke_time.studentID WHERE total_time > 100GROUP BY tuanke_time.studentID

加上where就报错说不存在total_time列,但是我看了明明存在啊

问题解答

回答1:

total_time 是你给SUM(tuanke_time.time)取得别名,数据库表字段本身没有这列吧。

查询total_time > 100,你可以试试

SELECT *FROM `tuanke_time` LEFT JOIN tuanke_student ON tuanke_student.Sid = tuanke_time.studentID GROUP BY tuanke_time.studentID having SUM(tuanke_time.time) > 100;回答2:

total_time是你在查询输出列中定义的,原来的表中没有这个列。

回答3:

外连接中on 和where是等效的,不能重复,直接去掉where

相关文章: