關于case when語句的報錯問題詳解
前言
在mysql數(shù)據(jù)庫中,有時候我們會使用到類似if else的判斷操作。那么mysql中怎么處理這種需求呢?
mysql 判斷操作一種語法:
case ..when語句
但最近在使用的時候遇到了一個問題,下面話不多說了,來一起看看詳細的介紹吧
直接說明問題。我有一張存儲身份證號碼的表id_card_message,表結構和數(shù)據(jù)如下(MySQL5.7.14):
mysql> select * from id_card_message; +------+--------------------+ | id | id_card_no | +------+--------------------+ | 1 | 342513199411222515 | | 1 | 342624197812023498 | | 1 | 310908198910123348 | +------+--------------------+
現(xiàn)在根據(jù)這個身份證號碼的倒數(shù)第二位來顯示出男女信息,我按照下面的SQL語句執(zhí)行,結果報出相應的錯誤:
mysql> select case substr(id_card_no,17,1) -> when (1,3,5,7,9) then '男' -> when (0,2,4,6,8) then '女' end 'sex', -> id_card_no -> from id_card_message; ERROR 1241 (21000): Operand should contain 1 column(s)
錯誤提示我:操作數(shù)應該包含一列。這里只能懷疑是when子句后面括號內的值過多的原因造成的,那么這種case when結構下,when子句后面只能出現(xiàn)一個值嗎?查了以下官方文檔在13.6.5.1節(jié)的case語法,貌似對這個沒有說明。
當然,換種語句格式,一樣能得到所需要的數(shù)據(jù)。如下:
mysql> select -> case -> when substr(id_card_no,17,1) in (1,3,5,7,9) then '男' -> when substr(id_card_no,17,1) in (0,2,4,6,8) then '女' end 'sex', -> id_card_no -> from id_card_message; +------+--------------------+ | sex | id_card_no | +------+--------------------+ | 男 | 342623199610222515 | | 男 | 342624197812023498 | | 女 | 310908198910123348 | +------+--------------------+
現(xiàn)在的想法就是,在“CASE value WHEN compare value”的格式下,when子句后面的compare value只能是單個值,不能接多個值。例如上面的compare value的值有1,3,5,7,9。這種情況下只能采用上面的SQL。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- MySQL 的CASE WHEN 語句使用說明
- SQL集合函數(shù)中case when then 使用技巧
- sql學習之CASE WHEN THEN ELSE END的用法
- MySQL的CASE WHEN語句的幾個使用實例
- MySQL中使用case when 語句實現(xiàn)多條件查詢的方法
- sql 中 case when 語法使用方法
- 淺析SQL語句行列轉換的兩種方法 case...when與pivot函數(shù)的應用
- sum(case when then)(判斷男女生的個數(shù))
- mysql case when group by 實例詳解
- MySQL排序中使用CASE WHEN的方法示例
相關文章
mysql報錯Duplicate entry ‘xxx‘ for key&nbs
有時候對表進行操作,例如加唯一鍵,或者插入數(shù)據(jù),會報錯,本文就來介紹一下mysql報錯Duplicate entry ‘xxx‘ for key ‘字段名‘的解決方法,感興趣的可以了解一下2023-10-10MySQL查詢空字段或非空字段(is null和not null)
本文介紹在MySQL中,面對值為空(NULL)的字段,應該如何查詢。怎么判斷一個字段的值為NULL或不為NULL,需要的朋友可以參考下2016-04-04IPv6設置后如何解決MySQL無法連接localhost的問題
這篇文章主要介紹了IPv6設置后如何解決MySQL無法連接localhost的問題,需要的朋友可以參考下2016-04-04