当前位置: 首页 > 编程笔记 >

shell中循环调用hive sql 脚本的方法

锺玺
2023-03-14
本文向大家介绍shell中循环调用hive sql 脚本的方法,包括了shell中循环调用hive sql 脚本的方法的使用技巧和注意事项,需要的朋友参考一下

脚本tt.sh的内容如下:

#!/bin/bash

params=$1
for param in $params
 do
 echo $param
 done

运行方式为:sh tt.sh "1 2 3 4 5"

输出为:

1
2
3
4
5

所以参考上面的命令,可以把hql的脚本写为如下方式,就可以循环执行sql:

功能:查找字符串 comments 中的param第一次出现的位置 ,返回的是位置数字

#!/bin/bash

params=$1
for param in $params
 do
 hive -e "insert overwrite local directory '/tmp/$param'
 row format delimited fields terminated by '\t'
 select locate('$param',comments) as position from tb_a;"
 done

功能:查找评论中出现关键字的内容,没有关键词的内容过滤掉

#!/bin/bash
params=$1
for param in $params
 do
 hive -e "insert overwrite local directory '/tmp/$param'
 row format delimited fields terminated by '\t'
 select position from 
  (select locate('$param',comments) as position from tb_a where position != '0') a 
 where a.position !='0' ;"
 done

以上这篇shell中循环调用hive sql 脚本的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍shell for循环、循环变量值付给其他shell脚本的方法,包括了shell for循环、循环变量值付给其他shell脚本的方法的使用技巧和注意事项,需要的朋友参考一下 本文主要将在shell中如何编写for循环,并将循环变量作为下个shell脚本的参数。 shell for 循环: 将循环变量赋值到下一个脚本: 在运行shell脚本时候,有三种方式来调用外部的脚本,exec(e

  • 问题内容: 我在实现for循环时遇到问题。执行脚本时出现此错误 test1.sh:2:语法错误:循环变量错误 我不明白这个错误。 这是我的剧本 谁能告诉我ubuntu中sh(在ubuntu中它链接到破折号外壳)shell中for循环的语法? 问题答案: 您可能使用而不是。尝试,或者如果它是可执行的,则不行。

  • 问题内容: 如何从外壳脚本内部执行Java方法? 问题答案: 您只能调用该方法。设计您的方法,使其调用所需的方法。 当我说 调用 方法时,您不会显式调用它。调用它是Java程序的唯一入口点。 如果您的班级看起来像: 您可以使用以下命令行在您可以找到的目录中调用from (如果您位于下面显示的结构的目录中): 如果要从其他目录(请参见下面的目录结构)执行此操作,则必须设置类路径。 为了清楚起见,请采

  • 6. Shell脚本的调试方法 Shell提供了一些用于调试脚本的选项,如下所示: -n 读一遍脚本中的命令但不执行,用于检查脚本中的语法错误 -v 一边执行脚本,一边将执行过的脚本命令打印到标准错误输出 -x 提供跟踪执行信息,将执行的每一条命令和结果依次打印出来 使用这些选项有三种方法,一是在命令行提供参数 $ sh -x ./script.sh 二是在脚本开头提供参数 #! /bin/sh

  • 本文向大家介绍详解Shell脚本中调用另一个Shell脚本的三种方式,包括了详解Shell脚本中调用另一个Shell脚本的三种方式的使用技巧和注意事项,需要的朋友参考一下 主要以下有几种方式: Command Explanation fork 新开一个子 Shell 执行,子 Shell 可以从父 Shell 继承环境变量,但是子 Shell 中的环境变量不会带回给父 Shell。 exec 在同

  • 问题内容: 是否有任何库允许我从Shell脚本调用JMX MBean方法。我们通过JMX公开了一些操作/管理命令,我们可以让管理员使用JConsole或VisualVM,但最好将某些任务留给自动化。在这种自动化中,我们希望能够在运行的服务器上调用JMX MBean方法,最好是从Shell脚本中调用。 问题答案: 可以使用以下命令行JMX实用程序: jmxterm-似乎是功能最齐全的实用程序。 cm

  • 用途:使用php将命令直接输入minecraft服务器控制台 我正在尝试使用php脚本(从浏览器运行)来执行shell脚本。当我从终端运行php时,它就可以工作了!但在浏览器中,什么都不会发生。 从终端运行时,我得到一个“数组0”,但浏览器给我一个“数组1” 问题是什么?一旦我运行了shell,之后的一切不应该像在终端上一样工作吗?(shell脚本内部的内容是否重要?) shell拥有所有rx权限

  • 本文向大家介绍Shell脚本中引用、调用另一个脚本文件的2种方法,包括了Shell脚本中引用、调用另一个脚本文件的2种方法的使用技巧和注意事项,需要的朋友参考一下 在Java,Python中,可以用import的方式来进行脚本或模块之间调用,例如: 在Shell中要如何调用别的shell脚本,或别的脚本中的变量,函数呢? 方法一:   . ./subscript.sh      方法二:   so