问题遇到的现象和发生背景
我要取用户id的后三位作为表中user_id字段的值,但用户id从1开始,这其中1、2、3、4均小于三位数,需要将这些数字补零,变为001、002、003、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中存在空值,插入数据报错
我的解答思路和尝试过的方法
我想要达到的结果
需要截取后三位,但有低于三位数字的值,需要补零