前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >shell 脚本执行带参数的hivesql

shell 脚本执行带参数的hivesql

作者头像
用户1217611
发布2022-05-06 16:17:07
4K0
发布2022-05-06 16:17:07
举报
文章被收录于专栏:文渊之博

目录

操作的表:

代码语言:javascript
复制
hive> select * from hbase_table_1;
OK
1       zhangsan
2       lisi

hive> desc hbase_table_1;
OK
key                     int                                         
value                   string 

变量可以在 linux 命令行下定义,也可以在 hive 命令行下定义。

在命令行下定义如下:

代码语言:javascript
复制
hive> set zzz=5;
hive> set zzz;
zzz=5
hive> set system:xxx=5;
hive> set system:xxx;
system:xxx=5
hive> set system:yyy=${system:xxx};
hive> set system:yyy;
system:yyy=5
hive> set go=${hiveconf:zzz};
hive> set go;
go=5
hive> set a=1;
hive> set b=a;
hive> set b;
b=a
hive> set c=${hiveconf:${hiveconf:b}};
hive> set c;
c=1

在 CLI 中定义如下几节描述:

1、在 shell 脚本中定义变量,在 hive -e 中使用

代码语言:javascript
复制
[root@zgg ~]# cat test.sh
table="hbase_table_1"
hive -e "desc $table"

[root@zgg ~]# sh test.sh
key                     int                                         
value                   string     

2、通过 --hiveconf 定义变量

在 hive -e 中使用

代码语言:javascript
复制
[root@zgg ~]# hive --hiveconf a=1 -e 'select * from hbase_table_1 where key=${hiveconf:a};'
....
1       zhangsan

在 hive -f 中使用

代码语言:javascript
复制
[root@zgg ~]# cat test.sql
select * from hbase_table_1 where key=${hiveconf:b};

[root@zgg ~]# hive --hiveconf b=2 -f test.sql
....
2       lisi

3、通过 --hivevar 定义变量

代码语言:javascript
复制
[root@zgg ~]# hive --hivevar a=1 -e 'select * from hbase_table_1 where key=${hivevar:a};'
....
1       zhangsan
代码语言:javascript
复制
[root@zgg ~]# cat test.sql
select * from hbase_table_1 where key=${hivevar:b};

[root@zgg ~]# hive --hivevar b=2 -f test.sql
....
2       lisi
  • Create a separate namespace for managing Hive variables.
  • Add support for setting variables on the command line via '-hivevar x=y'
  • Add support for setting variables through the CLI via 'set hivevar:x=y'
  • Add support for referencing variables in statements using either '{hivevar:var_name}' or '{var_name}'
  • Provide a means for differentiating between hiveconf, hivevar, system, and environment properties in the output of 'set -v'

原文连接:https://issues.apache.org/jira/browse/HIVE-2020

4、通过 -define 定义变量

-define 可以简写为 -d

代码语言:javascript
复制
[root@zgg ~]# hive -d a=1 -e 'select * from hbase_table_1 where key=${a};'
....
1       zhangsan
代码语言:javascript
复制
[root@zgg ~]# cat test.sql
select * from hbase_table_1 where key=${b};

[root@zgg ~]# hive -d b=2 -f test.sql
....
2       lisi
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-01-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、在 shell 脚本中定义变量,在 hive -e 中使用
  • 2、通过 --hiveconf 定义变量
  • 3、通过 --hivevar 定义变量
  • 4、通过 -define 定义变量
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档