温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SQL在业务中使用if存在的问题是什么

发布时间:2021-11-09 19:04:26 来源:亿速云 阅读:143 作者:柒染 栏目:大数据

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 使用最好,但是也需要注意业务场景,穷尽业务可能性;

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql
AI