五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

關(guān)于case when語句的報錯問題詳解

發(fā)布日期:2022-03-21 11:23 | 文章來源:站長之家

在mysql數(shù)據(jù)庫中,有時候我們會使用到類似if else的判斷操作。那么mysql中怎么處理這種需求呢?

mysql 判斷操作一種語法:

case ..when語句

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

直接說明問題。我有一張存儲身份證號碼的表id_card_message,表結(jié)構(gòu)和數(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í)行,結(jié)果報出相應(yīng)的錯誤:

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ù)應(yīng)該包含一列。這里只能懷疑是when子句后面括號內(nèi)的值過多的原因造成的,那么這種case when結(jié)構(gòu)下,when子句后面只能出現(xiàn)一個值嗎?查了以下官方文檔在13.6.5.1節(jié)的case語法,貌似對這個沒有說明。

當(dāng)然,換種語句格式,一樣能得到所需要的數(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。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對本站的支持。

海外服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部