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

问题遇到的现象和发生背景
我要取用户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中存在空值,插入数据报错

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

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


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.0,2.0,3.0,并非001,002,003


```sql
CASE WHEN LENGTH(tblA.com_id)>3 THEN SUBSTR(tblA.com_id,-3,3) ELSE SUBSTR(CONCAT('000',tblA.com_id),-3,3) END AS pt

```