文章详情页
MYSQL中如何把SELECT A AS B中的B作为WHERE筛选条件
浏览:86日期:2022-06-18 14:10:06
问题描述
比如SELECT a AS b WHRER b=1;
我这样使用会报错,说b不存在。
问题解答
回答1:因为mysql底层跑SQL语句时:where 后的筛选条件在先, as B的别名在后。所以机器看到where 后的别名是不认的,所以会报说B不存在。
如果非要用B做筛选条件的话:解决方案:外边再嵌套一层。select * from(select A as B from table) t where t.B = XXX -- 任意的筛选条件
如果不嵌套,只能用A做筛选条件了
回答2:当然不存在,这个b只针对与a查询结果的一个别名 select a AS b FROM table where a = 1
回答3:select t.b from(
select a as B from table
) t
where t.b =xxxx
此时的B是可以直接在where中使用的
回答4:b是对查询结果a取的别名where里面肯定是不存在啊
上一条:MySQL 获得执行结果下一条:mysql,in中重复的记录也查出的方法
相关文章:
1. 如何修改phpstudy的phpmyadmin放到其他地方2. php - mysql中,作为主键的字段,用int类型,是不是比用char类型的效率更高?3. tp6表单令牌4. docker 17.03 怎么配置 registry mirror ?5. django - 后台返回的json数据经过Base64加密,获取时用python如何解密~!6. 我的html页面一提交,网页便显示出了我的php代码,求问是什么原因?7. 网络传输协议 - 以下三种下载方式有什么不同?如何用python模拟下载器下载?8. angular.js - Angular路由和express路由的组合使用问题9. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?10. java 排序的问题
排行榜
