91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

case when語句報錯怎么辦

發布時間:2021-07-15 09:37:55 來源:億速云 閱讀:247 作者:小新 欄目:MySQL數據庫

這篇文章主要介紹case when語句報錯怎么辦,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

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,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 |

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

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

以上是“case when語句報錯怎么辦”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

外汇| 高唐县| 吉林省| 丰台区| 化德县| 南开区| 嘉峪关市| 衢州市| 大洼县| 万载县| 塘沽区| 泰兴市| 吴忠市| 东阿县| 井冈山市| 花莲县| 汉沽区| 盱眙县| 蕉岭县| 江川县| 家居| 合作市| 石家庄市| 乐清市| 金坛市| 永济市| 马边| 玉溪市| 政和县| 富裕县| 故城县| 隆子县| 沅陵县| 兴海县| 兴业县| 通州市| 彭山县| 建阳市| 襄樊市| 互助| 天门市|