sql语句中数据库别名命名和查询问题解析
查询出低于菜品平均价格的菜品信息 (展示出菜品名称、菜品价格).
问题1 :为什么下面代码不对
select d.name,d.price,avg(d.price)
from dish as d
where d.price < avg(d.price)聚合函数使用错误:
- AVG(d.price)是一个聚合函数,但它被用在了WHERE子句中。在SQL中,聚合函数不能直接在WHERE子句中使用,(where可以用,写其他的语句,不能出现聚合函数的语句)因为WHERE子句是在行级别过滤数据,而聚合函数是在多行数据上计算。
2… 逻辑顺序问题:SQL执行顺序是FROM→WHERE→GROUP BY→HAVING→SELECT 。WHERE子句在聚合计算之前执行,所以此时还没有计算平均值。
问题2 :为什么下面的语句还是查不到?
select *
from dish as d
where d.price < (select avg(d.price) from dish);因为起了别名就要使用别名,原来的数据库名字就查不到了。所以内层循环 不使用d或者 使用 dish as d 即可查询成功。即内层查询应避免使用外层别名 或 统一使用。
正确方法

到此这篇关于MySql:sql语句中数据库别名命名和查询问题的文章就介绍到这了,更多相关sql数据库别名命名内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SQL Server 2022新功能之如何将数据库备份到S3兼容的对象存储
本文介绍了如何使用SQL Server 2022将数据库备份到S3兼容的对象存储,主要功能包括配置S3连接器、创建凭据、使用URL进行备份和恢复,并支持加密和压缩选项,此外,还讨论了在Linux平台上的特殊配置要求和区域参数的使用,感兴趣的朋友一起看看吧2025-02-02
SQLserver查询数据类型为ntext是空或NULL值的方法
SQLserver查询数据类型为ntext是空或NULL值的方法2010-07-07
asp.net 使用SqlBulkCopy极速插入数据到 SQL Server
今天早上reader 上收到cnblogs的订阅里看到一个关于SQL语句快速插入的文章,提到SqlBulkCopy,感觉不错,按他的测试SqlBulkCopy要比普通插入快近30倍,2010-04-04
详细分析sqlserver中的小数类型(float和decimal)
这篇文章主要介绍了sqlserver中的小数类型的相关知识,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下2020-06-06


最新评论