从品牌网站建设到网络营销策划,从策略到执行的一站式服务
SQL在业务中使用if存在的问题是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站设计、成都网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的武乡网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
if(true,'1','0')
在sql中 if 是非此即彼的选择,因此使用时需要注意业务问题:
举例:
判断用户是否新注册或者老注册用户
select
tb.*
,if(t_user.user_id is not null,'新注册用户','老注册用户') as new_sign_user
from tb
left join t_user ## 用户id是唯一性的
on tb.ds = t_user.ds
and tb.user_id = t_user.user_id
在新老注册用户是没有任何问题,因为用户只有两种属性,要么是新注册,要么是老注册,用if没有问题;
select
tb.*
,case when t_first_pay.from_user_id is not null and t_first_pay.ds < tb.ds then '老付费'
when t_first_pay.from_user_id is not null and t_first_pay.ds = tb.ds then '新付费'
else '未付费' end as new_pay_user
from tb
left join t_trade_flow_first_type as t_first_pay ## 用户首次付费
on tb.ds = t_first_pay.ds
and tb.user_id =t_first_pay.user_id
付费用户有三种属性,老付费属性、新付费属性、未付费,因此不能再使用了if 判定,需要使用case when 进行多重判定;
if 使用最好,但是也需要注意业务场景,穷尽业务可能性;
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图