我要取用户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中存在空值,插入数据报错
需要截取后三位,但有低于三位数字的值,需要补零
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
```