时间:2021-04-16
前一段时间进行一段比较复杂的数据库业务查询需要对查询出来的数据进行分类统计 ,用到了数据库的case函数,这时才注意到这个函数有两种用。
一种是:
case 字段名 when 字段值 then 值 else 值2 end
这一种是之前比较常用的一种方式,相当于是大部分编程语言中的switch case的用法,通过字段名,去匹配字段值,适合字段值比较固定的情况下使用,特点是比较简洁易用。
还有一种:
case when 条件 then 值 else 值2 end
这一种应该用过的人比较少一些,一般情况下也不需要使用这种判断方式,如果情况允许的话,最好是在where子句中进行条件筛选,避免数据库不必要的性能消耗。但是一些特殊的情况下还是会用到的。这种用法的特点其他编程语言中的if else条件语句十分相似的 when后面的是一个条件表达式,根据表达式的结果来进行决定是否为then后面的值,使用起来比较灵活,可以适应更多的复杂情况。
事实上绝大部分的第一种用法都是可以转换为第二种的形式来写的,但是这样写的时候会显得SQL语句比较繁琐,不易阅读,大部分情况下还是建议使用第一种用法,如果遇到无法处理的情况下再使用第二种进行处理。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
超强:SQL命令中的case...when...then...else...end条件查询(不同于where)与类型转换的用法case...when...the
本文实例讲述了MySQL流程函数常见用法。分享给大家供大家参考,具体如下:流程函数是MySQL相对常用的一类函数,用户可以使用这类函数在一个SQL语句中实现条件
在Transact-SQL语句中,我们主要使用OpenDataSource函数、OPENROWSET函数,关于函数的详细说明,请参考SQL联机帮助。利用下述方法
1.组函数用法规则mysql中组函数在select语句中可以随意使用,但在oracle中如果查询语句中有组函数,那其他列名必须是组函数处理过的,或者是group
关键字defundef方法定义module模块定义class类定义defined?检查类型条件语句if,then,else,elsif,case,when,un