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数据库外连接,内连接,自然连接

    create table join_teacher(id int primary key auto_increment,t_name varchar(10) not null,gender enum(‘male’,’female’,’secret’) not null)engine innodb character set utf8;insert into …

    MySQL 2023年4月13日
    00
  • 连接docker里面的mysql失败解决方法

    当我们在使用Docker时,有时候需要连接容器内部的MySQL数据库来进行数据操作,但是有时候会遇到连接失败的问题。下面是连接docker里面的mysql失败解决方法的攻略。 问题描述 当我们尝试连接Docker容器内部的MySQL数据库时,会遇到如下错误: ERROR 2003 (HY000): Can’t connect to MySQL server …

    MySQL 2023年5月18日
    00
  • 查看当前mysql数据库实例中,支持的字符集有哪些,或者是否支持某个特定字符集

    需求描述:   查看当前mysql实例中支持哪些字符集,过滤特定的字符集 操作过程: 1.通过show character set来进行查看 mysql> show character set; +———-+———————————+———————+——–+ |…

    MySQL 2023年4月13日
    00
  • MySQL出现SQL Error (2013)连接错误的解决方法

    MySQL出现SQL Error (2013)连接错误是 MySQL 数据库连接失败的一种常见问题,通常是由于与 MySQL 数据库通信超时或者网络故障引起的。 解决这个问题的方法包括检查网络设置、调整 MySQL 配置、检查服务是否运行并且重启服务等多个步骤。 下面分步骤详细讲解“MySQL出现SQL Error (2013)连接错误的解决方法”: 第一步…

    MySQL 2023年5月18日
    00
  • mysql中,创建包含json数据类型的表?创建json表时候的注意事项?查询json字段中某个key的值?

    需求描述:   在mysql数据库中,创建包含json数据类型的表.记录下,在创建的过程中,需要注意的问题. 操作过程: 1.通过以下的语句,创建包含json数据类型的表 mysql> create table tab_json(id bigint not null auto_increment,data json,primary key(id)); …

    MySQL 2023年4月13日
    00
  • GreatSQL社区月报 | 2023.03

    GreatSQL社区月报 | 2023.03 GreatSQL 是一个开源的 MySQL 技术路线数据库社区,社区致力于通过开放的社区合作,构建国内自主 MySQL 版本及开源数据库技术,推动中国开源数据库及应用生态繁荣发展。 为了帮助社区的小伙伴们更好地了解 GreatSQL 社区的实时进展,我们决定每月更新发布一次 GreatSQL 社区月报。月报的主要…

    MySQL 2023年4月17日
    00
  • CentOS7 安装MySQL8修改密码

    1. 添加MySQL8的本地源 执行以下命令获取安装MySQL源 [root@virde ~]# wget https://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm [root@virde ~]# sudo yum localinstall mysql80-community-rel…

    MySQL 2023年4月13日
    00
  • 对比 elasticsearch 和 mysql

    对比 elasticsearch 和 mysql 最近阅读了elasticsearch的官方文档,学习了它的很多特性,发现elasticsearch和mysql有很多地方类似,也有很多地方不同。这里做一个对比,帮助大家加深对elasticsearch的理解。 特性 elasticsearch mysql 备注 场景 全文搜索,日志处理,空间数据分析 表结构存…

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