文章詳情頁
MYSQL中如何把SELECT A AS B中的B作為WHERE篩選條件
瀏覽:89日期: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. 數據庫 - mysql如何處理數據變化中的事務?2. java - ehcache緩存用的是虛擬機內存么?3. javascript - JS如何取對稱范圍的隨機數?4. java - mongodb分片集群下,count和聚合統計問題5. 關于docker下的nginx壓力測試6. android - java 泛型不支持數組,那么RxJava的Map集合有什么方便的手段可以定義獲得一串共同父類集合數據呢?7. javascript - 有什么兼容性比較好的辦法來判斷瀏覽器窗口的類型?8. python - pandas按照列A和列B分組,將列C求平均數,怎樣才能生成一個列A,B,C的dataframe9. dockerfile - 我用docker build的時候出現下邊問題 麻煩幫我看一下10. dockerfile - [docker build image失敗- npm install]
排行榜
