case when语句报错怎么办
发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要介绍case when语句报错怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql 判断操作一种语法:case ..when语句但最近在使用的时候遇到了一
千家信息网最后更新 2025年02月02日case when语句报错怎么办
这篇文章主要介绍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语句报错怎么办"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!
语句
子句
面的
怎么办
内容
号码
数据
格式
篇文章
结构
语法
身份
身份证
错误
问题
价值
信息
兴趣
单个
原因
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
重庆有哪些计算机网络技术学校
dell虚拟机服务器配置
计算机网络技术人员职业类别
服务器硬盘推荐
子公司网络安全
win 服务器系统
网络技术薪酬方案
为什么要定制网络安全法
实况足球中国官方服务器
数据库中图片存成什么类型
中国网络安全投诉电话
软件开发的步骤
网络安全法二十一条是什么
软件开发培训班上班时间
网络安全法最根本意义在于
网络安全专业技术支持队伍
网络安全保卫大队见习
国家网络安全保护要求
河湖划界数据库建设
下列语句中用来删除数据库的是
宜保网络技术
苹果id注册无法连接到服务器
苹果13服务器连接失败
上海银行微服务架构数据库
数据库技术数据分析
数据库查询语句分页
杭州直播软件开发哪家有名
网络游戏新开服务器
连接两个数据库表并去除相同字段
天堂文件数据库