想要每天查询的表名都带着昨天的日期,在hive里面 表名怎么加昨天的日期,比如A_20220103
hive>select concat('A','_',regexp_replace(substr(date_sub(FROM_UNIXTIME(UNIX_TIMESTAMP()),1),1,10),'-',''));
A_20220103 -- 这个可以实现,但是我使用的是sql查询,但是报错。
我使用的是插入sql如下:
select 1 from concat('A','_',regexp_replace(substr(date_sub(FROM_UNIXTIME(UNIX_TIMESTAMP()),1),1,10),'-',''));
hive> select 1 from concat('A','_',regexp_replace(substr(date_sub(FROM_UNIXTIME(UNIX_TIMESTAMP()),1),1,10),'-',''));
FAILED: ParseException line 1:20 missing EOF at '(' near 'concat' -- 此报错如何解决,求助大佬,谢谢。
你第一个sql只是拼出一个字符串,并不是表名,当然不能直接代替表使用。
像这种字符串拼接出来sql叫动态sql,不能直接作为sql执行,必须以程序化命令,比如存储过程、shell之类的,先拼出来完整的sql,再去执行这个sql
你可以写shell脚本,表名作为变量