Mysql 中,为什么 WHERE 使用别名会报错,而 ORDER BY 不会报错?

 

  Mysql 中,为什么 WHERE 使用别名会报错,而 ORDER BY 不会报错?

 我们先对salary * 12 命名一个别名annual_sal

SELECT employee_id,salary,salary * 12 annual_sal
FROM employees
ORDER BY annual_sal;

 这段代码以annual_sal升序输出且正常执行没有报错。说明order by 可以使用别名

 我们再看看这个段代码

SELECT employee_id,salary,salary * 12 annual_sal
FROM employees
WHERE annual_sal > 81600
ORDER BY annual_sal;

这段代码就报错了,报错说明是Unknown column 'annual_sal' in 'where clause'。由此可以得出where语句执行是找不到annual_sal.

要解决这个问题,我们必须知道sql语句执行顺序。

  1. 先执行from语句用哪个表
  2. where过滤条件(这时候不知道别名)
  3. select选择输出字段 (这时候才有别名)
  4. order by进行排序   (order by 才能使用别名)

总结一下:因为where在sql中执行顺序在select(创建别名)之前,所以找不到别名。

 

原文链接:https://www.cnblogs.com/cobral/p/17320854.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Mysql 中,为什么 WHERE 使用别名会报错,而 ORDER BY 不会报错? - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • 详解MySQL HAVING:过滤分组

    HAVING是MySQL用于在GROUP BY子句之后对数据进行过滤的关键字,HAVING的使用方式与WHERE相似,可以使用诸如SUM、AVG等聚合函数、关系运算符、逻辑运算符等对数据进行筛选。在使用HAVING之前,需要先进行GROUP BY操作,将数据按照一定规则分组。 下面是一些示例说明: 假设有一个订单表orders,包含以下字段: order_i…

    MySQL 2023年3月9日
    00
  • MySQL8.0.32的安装与配置超详细图文教程

    让我来为你详细讲解“MySQL8.0.32的安装与配置超详细图文教程”的完整攻略。 准备工作 在开始安装前,你需要先准备以下的工作: 下载MySQL8.0.32安装包。你可以从MySQL官网上下载对应的安装包。下载好后将其解压到一个你喜欢的目录中。 确保已经安装了Visual C++ Redistributable for Visual Studio 201…

    MySQL 2023年5月19日
    00
  • PyQt5连接MySQL及QMYSQL driver not loaded错误解决

    请参考下面的完整攻略来解决“PyQt5连接MySQL及QMYSQL driver not loaded错误”的问题。 1. 安装MySQL驱动 为了能够连接MySQL,我们需要使用Qt提供的QMYSQL driver。在PyQt5中,该驱动可以通过安装PyMySQL实现。 执行以下命令进行安装: pip install pymysql 或者使用以下命令安装预…

    MySQL 2023年5月18日
    00
  • MySQL 如何实现数据插入

    使用MySQL插入数据时,可以根据需求场景选择合适的插入语句,例如当数据重复时如何插入数据,如何从另一个表导入数据,如何批量插入数据等场景。本文通过给出每个使用场景下的实例来说明数据插入的实现过程和方法。 使用MySQL插入数据时,可以根据需求场景选择合适的插入语句,例如当数据重复时如何插入数据,如何从另一个表导入数据,如何批量插入数据等场景。本文通过给出每…

    MySQL 2023年4月12日
    00
  • MySQL8.0无法启动3534的解决方法

    以下是针对MySQL8.0无法启动3534的解决方法的完整攻略: 1. 确认错误信息 当MySQL8.0无法启动,提示“[ERROR] [MY-012574] [InnoDB] Plugin initialization aborted with error Generic error”等类似错误信息时,需要先确认错误信息并记录下来。 2. 检查配置文件 执…

    MySQL 2023年5月18日
    00
  • linux 环境 mysql写入中文报错

    针对“linux 环境 mysql写入中文报错”的问题,我们可以从以下几个方面来进行完整的解答,包括: 确定数据库字符集 修改数据库字符集 修改数据表字符集 修改数据字段字符集 常见报错及解决方法 接下来我将分别进行详细的讲解。 1. 确定数据库字符集 在进行后续的处理之前,我们需要先确定数据库字符集是否正确。可以通过以下命令查询当前数据库字符集: show…

    MySQL 2023年5月18日
    00
  • mysql kill process解决死锁

          SHOW PROCESSLIST 2、 查询语句把表锁住了, 赶紧找出第一个Locked的thread_id, 在MySQL的shell里面执行. kill  id #!/bin/bashmysql -u root -e “show processlist” | grep -i “Locked” >> locked_log.txt f…

    MySQL 2023年4月12日
    00
  • 如何提高MySQL Limit查询性能的方法详解

    关于提高MySQL Limit查询性能的方法,以下是一些攻略可以帮助你。 1. 使用索引 在一个大的MySQL表中,使用限制查询(LIMIT query)是很常见的操作。这样可以一次性获取需要的数据结果,而不必一次加载整个表,从而提高了查询效率。但这种方法在大型数据表上使用会出现性能问题。因为MySQL对于LIMIT查询的优化有限,会遇到必须扫描整个表才能找…

    MySQL 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部