这条sql语句为什么加上where就报错?
高洛峰
高洛峰 2016-11-19 15:09:06
0
3
1399

wKioL1guYhOjQXvkAAA8PZ7t7wQ318.png

wKioL1guYhOjQXvkAAA8PZ7t7wQ318.png

这条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 > 100
GROUP BY tuanke_time.studentID

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

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

Antworte allen(3)
三叔

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

学霸

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

三叔

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;


Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!