文章详情页
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
相关文章:
1. 如何解决Centos下Docker服务启动无响应,且输入docker命令无响应?2. javascript - vue 数据更新了。但是dom没有更新,,,,,如图3. css3中translate(-50%,-50%)对 transform-origin的奇葩影响?4. 如何调整IDEA中直接运行java程序的日志输出级别?5. javascript - 静态页面引公共头尾文件,js怎么写吖?6. mysql - sql 中 group 和field 查询问题。7. 数据表里没数据显示8. 老师,layui.css无法使用,路径都是按照视频照做的,是不是还有其他步骤需要做?9. java基础,求解答。10. php mysql_query()问题
排行榜