MySql Case查询

MySql Case查询,第1张

例子:根据用户id与身份查询用户名称:教师与学生分为两个表存储

select a.*,case a.a_user_identity when 0 then (select t.teacherNameChs from teacherinfo t where teacherId =a.a_user_id) else (select s.studentNameChs from studentinfo s where s.studentId =a.a_user_id)

end as username

from advice a

简单 CASE 函数

CASE input_expression

    WHEN when_expression THEN result_expression

        [ ...n ]

    [ 

        ELSE else_result_expression

    END

CASE 搜索函数:

CASE    

WHEN Boolean_expression THEN result_expression

        [ ...n ]

    [ 

        ELSE else_result_expression

    END

比如:

第一种用法:

SELECT name,

       CASE WHEN birthday < '1981' THEN 'old' 

            WHEN birthday > '1988' THEN 'yong'

            ELSE 'ok' END YORN

FROM lee

第二种用法:

SELECT NAME, CASE name

    WHEN 'sam' THEN 'yong'

    WHEN 'lee' THEN 'handsome'

    ELSE 'good'  END as oldname

FROM lee


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7382430.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存