国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > 幫助中心 > 正文

關(guān)于case when語句的報(bào)錯(cuò)問題詳解

2024-07-09 22:47:55
字體:
供稿:網(wǎng)友

前言

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

mysql 判斷操作一種語法:

case ..when語句

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

直接說明問題。我有一張存儲(chǔ)身份證號(hào)碼的表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ù)這個(gè)身份證號(hào)碼的倒數(shù)第二位來顯示出男女信息,我按照下面的SQL語句執(zhí)行,結(jié)果報(bào)出相應(yīng)的錯(cuò)誤:

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)

錯(cuò)誤提示我:操作數(shù)應(yīng)該包含一列。這里只能懷疑是when子句后面括號(hào)內(nèi)的值過多的原因造成的,那么這種case when結(jié)構(gòu)下,when子句后面只能出現(xiàn)一個(gè)值嗎?查了以下官方文檔在13.6.5.1節(jié)的case語法,貌似對(duì)這個(gè)沒有說明。

當(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只能是單個(gè)值,不能接多個(gè)值。例如上面的compare value的值有1,3,5,7,9。這種情況下只能采用上面的SQL。

總結(jié)

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

您可能感興趣的文章:

MySQL 的CASE WHEN 語句使用說明MySQL的CASE WHEN語句的幾個(gè)使用實(shí)例MySQL中使用case when 語句實(shí)現(xiàn)多條件查詢的方法淺析SQL語句行列轉(zhuǎn)換的兩種方法 case...when與pivot函數(shù)的應(yīng)用SQL集合函數(shù)中case when then 使用技巧sql學(xué)習(xí)之CASE WHEN THEN ELSE END的用法sql 中 case when 語法使用方法sum(case when then)(判斷男女生的個(gè)數(shù))
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 玛曲县| 普兰店市| 襄城县| 武宁县| 杂多县| 密云县| 临泽县| 白沙| 桦甸市| 博客| 西乌珠穆沁旗| 和平区| 永清县| 武安市| 慈溪市| 南涧| 营山县| 城口县| 上蔡县| 武宁县| 河北区| 大田县| 鹤岗市| 榆中县| 许昌县| 澜沧| 通河县| 竹山县| 临泽县| 乐都县| 花莲县| 克山县| 睢宁县| 延津县| 镇雄县| 上蔡县| 江川县| 阿荣旗| 上高县| 开阳县| 柏乡县|