当前位置: 首页 > news >正文

MySql:sql语句中数据库别名命名和查询问题

文章目录

  • 查询出低于菜品平均价格的菜品信息 (展示出菜品名称、菜品价格).
    • 问题1 :为什么下面代码不对
    • 问题2 :为什么下面的语句还是查不到?
    • 正确方法

查询出低于菜品平均价格的菜品信息 (展示出菜品名称、菜品价格).

问题1 :为什么下面代码不对

	select d.name,d.price,avg(d.price)from dish as dwhere d.price < avg(d.price)

聚合函数使用错误:

  1. AVG(d.price)是一个聚合函数,但它被用在了WHERE子句中。在SQL中,聚合函数不能直接在WHERE子句中使用,(where可以用,写其他的语句,不能出现聚合函数的语句)因为WHERE子句是在行级别过滤数据,而聚合函数是在多行数据上计算。

2… 逻辑顺序问题:SQL执行顺序是FROM→WHERE→GROUP BY→HAVING→SELECT 。WHERE子句在聚合计算之前执行,所以此时还没有计算平均值。

问题2 :为什么下面的语句还是查不到?

    select *from dish as dwhere d.price < (select avg(d.price) from dish);

因为起了别名就要使用别名,原来的数据库名字就查不到了。所以内层循环 不使用d或者 使用 dish as d 即可查询成功。即内层查询应避免使用外层别名 或 统一使用。

正确方法

在这里插入图片描述

http://www.dtcms.com/a/279645.html

相关文章:

  • 什么是存储引擎以及MySQL常见的三种数据库存储引擎
  • Kotlin Map映射转换
  • 游戏玩法的专利博弈
  • Python:打造你的HTTP应用帝国
  • 内容管理系统指南:企业内容运营的核心引擎
  • 宝塔面板常见问题
  • c++算法一
  • GNhao,长期使用跨境手机SIM卡成为新趋势!
  • LeetCode 692题解 | 前K个高频单词
  • VScode链接服务器一直卡在下载vscode服务器/scp上传服务器,无法连接成功
  • 【DataWhale】快乐学习大模型 | 202507,Task01笔记
  • 总结一下找素数的三种方法
  • Python3完全新手小白的学习手册 13-1项目篇《外星人入侵》
  • MFC中BOOL类型,在某些操作系统中,-1不能被识别,一般是哪些原因?
  • MFC UI控件CheckBox从专家到小白
  • MFC UI表格制作从专家到入门
  • Cocos Creator 高斯模糊效果实现解析
  • 《星盘接口2:NVMe风暴》
  • C++_编程提升_temaplate模板_案例
  • ether.js—3—contract
  • 高密度PCB板生产厂商深度解析
  • Docker容器操作命令大全
  • C++-linux 7.文件IO(一)系统调用
  • 是时候重估蔚来的技术价值了
  • 【科研绘图系列】R语言绘制世界地图
  • python的小学课外综合管理系统
  • MMpretrain 中的 LinearClsHead 结构与优化
  • 分布式光伏并网中出现的电能质量问题,如何监测与治理?
  • 【数据库】慢SQL优化 - MYSQL
  • 系统调用入口机制:多架构对比理解(以 ARM64 为主)