今天也要学习呐 2022-01-20 12:10 采纳率: 68.2%
浏览 28
已结题

需要截取后三位,但有低于三位数字的值,需要补零

问题遇到的现象和发生背景
我要取用户id的后三位作为表中user_id字段的值,但用户id从1开始,这其中1、2、3、4均小于三位数,需要将这些数字补零,变为001、002003、004插入到我的表中

问题相关代码,请勿粘贴截图
INSERT OVERWRITE TABLE bbb PARTITION(dd,uid)
SELECT 
        dat,
        CAST(SUBSTR(tblA.ds,1,6) AS BIGINT ) AS dd,
        SUBSTR(tblA.user_id,-3,3) AS uid
FROM aaa tblA
WHERE tblA.ds=20200201;
运行结果及报错内容

uid中存在空值,插入数据报错

我的解答思路和尝试过的方法
我想要达到的结果

需要截取后三位,但有低于三位数字的值,需要补零

  • 写回答

2条回答 默认 最新

  • Hello World, 2022-01-20 12:16
    关注
    
    SELECT CASE WHEN LEN(tblA.[user_id])>3 tblA.[user_id] ELSE RIGHT('000' + tblA.[user_id],3) END AS [user_id] FROM aaa tblA
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月28日
  • 已采纳回答 1月20日
  • 创建了问题 1月20日