case when语句报错该如何处理?

Posted Chihiro.511

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了case when语句报错该如何处理?相关的知识,希望对你有一定的参考价值。

本篇文章主要介绍的是case when语句报错该如何处理,内容讲解的非常详细,且具有一定的实用价值。对于这方面不清楚的朋友,小杜我希望大家看完之后有所帮助,因此,感兴趣的朋友一定要看完!

mysql判断操作的一种语法:

case …when语句

但最近在使用的时候碰到了一个问题,接下来就不多说了,一起来看看详细的介绍吧。

直接说明问题,我有一张存储身份证号码的表id_card_message,表结构和数据如下(mysql5.7.14):
在这里插入图片描述

现在按照这个身份证号码的最后第二位来显示出男女信息,我按照下边的SQL语句执行,结果报出相应的错误:
在这里插入图片描述

错误提示我:操作数应该包含一列。这里只能怀疑是when子句后面括号内的值过多的原因造成的,那么这种case when结构下,when子句后面只能出现一个值吗?查了以下官方文档在13.6.5.1节的case语法,貌似对这个没有说明。

当然,换种语句格式,一样能得到所需要的数据。如下:
在这里插入图片描述

现在的想法就是,在“CASE value WHEN compare value”的格式下,when子句后面的compare value只能是单个值,不能接多个值。例如上面的compare value的值有1,3,5,7,9。这种情况下只能采用上面的SQL。

本篇文章关于“case when语句报错该怎么处理”的介绍就到此完毕,感谢各位的阅读!希望大家看完之后有所帮助,感谢各位对摩杜云的支持。如果觉得这篇文章不错的,可以分享给更多的人看到!

以上是关于case when语句报错该如何处理?的主要内容,如果未能解决你的问题,请参考以下文章

SQL 中 where 条件中 in 后面 加 CASE WHEN 语句 报错

sql 的case when 语句

突如其来的“中断异常”,我(Java)该如何处理?

关于CUDA5之后cutil.h不可用的问题

shell编程写了一个case嵌套if和for的语句,一直报错,求大虾指教

Oracle 条件索引 case when 报错解决方案