mysql case when

MySQL中case when的用法:

select f1,case [f2] 

when expression1 then value1

when expression2 then value2

else value3

end alias_field

from table;


相当于代码中的:

if(expression1 ){
alias_field = value1;
}elseif(expression2 ){
alias_field = value2;
}else{
alias_field = value3;
}



case [f2] 表示f2这个字段是可选的,expression是一个条件表达式或常量,value是一个值,在expression和value中都可以使用字段的值进行判断或运算;

比如一个活动数据表,每个活动都有开始时间和结束时间,在展示时要求将正在进行中的活动排在前面,未开始的排在中间,已结束的排在最后

活动表:activity

id 主键

activity_name 活动名称

start_time 活动开始时间

end_time 活动结束时间


按如上排序规则查询活动数据:

select id,activity_name,
case
                    when end_time < unix_timestamp(now())  then  -1   /*已结束*/
                    when start_time < unix_timestamp(now()) and end_time > unix_timestamp(now())  then  1     /*进行中*/
                    else 0      /*未开始*/
                    end order_number
from activity order by order_number desc limit 1,10;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值