1. 程式人生 > 資料庫 >關於case when語句的報錯問題詳解

關於case when語句的報錯問題詳解

前言

在mysql資料庫中,有時候我們會使用到類似if else的判斷操作。那麼mysql中怎麼處理這種需求呢?

mysql 判斷操作一種語法:

case ..when語句

但最近在使用的時候遇到了一個問題,下面話不多說了,來一起看看詳細的介紹吧

直接說明問題。我有一張儲存身份證號碼的表id_card_message,表結構和資料如下(MySQL5.7.14):

mysql> select * from id_card_message;

+------+--------------------+

| id | id_card_no |

+------+--------------------+

| 1 | 342513199411222515 |

| 1 | 342624197812023498 |

| 1 | 310908198910123348 |

+------+--------------------+

現在根據這個身份證號碼的倒數第二位來顯示出男女資訊,我按照下面的SQL語句執行,結果報出相應的錯誤:

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)

錯誤提示我:運算元應該包含一列。這裡只能懷疑是when子句後面括號內的值過多的原因造成的,那麼這種case when結構下,when子句後面只能出現一個值嗎?查了以下官方文件在13.6.5.1節的case語法,貌似對這個沒有說明。

當然,換種語句格式,一樣能得到所需要的資料。如下:

mysql> select

-> case

-> when substr(id_card_no,1) in (1,9) then '男'

-> when substr(id_card_no,1) in (0,-> id_card_no

-> from id_card_message;

+------+--------------------+

| sex | id_card_no |

+------+--------------------+

| 男 | 342623199610222515 |

| 男 | 342624197812023498 |

| 女 | 310908198910123348 |

+------+--------------------+

現在的想法就是,在“CASE value WHEN compare value”的格式下,when子句後面的compare value只能是單個值,不能接多個值。例如上面的compare value的值有1,9。這種情況下只能採用上面的SQL。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對我們的支援。