文章详情页
mysql - 这条sql语句为什么加上where就报错?
浏览:231日期:2022-06-17 09:07:17
问题描述


这条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
相关文章:
1. 如何解决docker宿主机无法访问容器中的服务?2. angular.js - angular内容过长展开收起效果3. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””4. javascript - 使用angular给图片动态赋值src属性出现unsafe的情况5. javascript - chart.js如何修改某个指定bar的颜色6. 为什么我ping不通我的docker容器呢???7. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题8. 请教使用PDO连接MSSQL数据库插入是乱码问题?9. Python如何利用Selenium或者PhantomJS爬取动态网页内容10. mysql - 一个sql的问题
排行榜

网公网安备