iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >hive存储过程怎么用
  • 868
分享到

hive存储过程怎么用

2023-06-02 03:06:43 868人浏览 八月长安
摘要

这篇文章主要介绍了Hive存储过程怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。hive存储过程简介x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发

这篇文章主要介绍了Hive存储过程怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

hive存储过程简介

x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发时候,一般是将一段一段的HQL语句封装在shell或者其他脚本中,然后以命令行的方式调用,完成一个业务或者一张报表的统计分析。好消息是,现在已经有了Hive存储过程的解决方案(HPL/sql –Procedural SQL on hadoop),并且在未来的Hive的版本(2.0)中,会将该模块集成进来。该解决方案不仅支持Hive,还支持在sparkSQL,其他NoSQL,甚至是RDBMS中使用类似于oracle PL/SQL的功能,这将极大的方便数据开发者的工作,Hive中很多之前比较难实现的功能,现在可以很方便的实现,比如自定义变量、基于一个结果集的游标、循环等等。

hplsql安装和存储过程案例

下载:

官网下载地址:自行下载哈,不附链接了

0.3.31版本下载地址:自行下载哈,不附链接了

安装hplsql:

[root@hadoop01 home]# tar -zxvf /home/hplsql-0.3.31.tar.gz -C /usr/local/

配置hplsql:

vi ./hplsql

内容如下:

#!/bin/bash

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/lib/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_CONF_DIR/"

                                           

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/mapReduce/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/mapreduce/lib/*"

                                                        

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/hdfs/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/hdfs/lib/*"

                                                        

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/yarn/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/yarn/lib/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/common/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HADOOP_HOME/share/hadoop/common/lib/*"

                                                        

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HIVE_HOME/lib/*"

export "HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HIVE_HOME/conf"

export HADOOP_OPTS="$HADOOP_OPTS -Djava.library.path=$HADOOP_HOME/lib/native"

SCRIPTPATH=${0%/*}

java -cp $SCRIPTPATH:$HADOOP_CLASSPATH:$SCRIPTPATH/hplsql-0.3.31.jar:$SCRIPTPATH/antlr-runtime-4.5.jar $HADOOP_OPTS org.apache.hive.hplsql.Hplsql "$@"

配置hive2的服务:

vi ./conf/hive-site.xml

追加内容如下:

  <property>

    <name>hive.server2.thrift.bind.host</name>

    <value>hadoop01</value>

  </property>

  <property>

    <name>hive.server2.thrift.port</name>

    <value>10000</value>

  </property>

重启hiveserver2:

nohup hive --service hiveserver2 > hiveserver2.log 2>&1 &

配置HPL/SQL与Hive的连接:

vi ./hplsql-site.xml

hive存储过程怎么用

使用hplsql -e执行命令:

[root@hadoop01 hplsql-0.3.31]# ./hplsql -e "CURRENT_DATE + 1"

2019-09-18

[root@hadoop01 hplsql-0.3.31]# ./hplsql -e "for i in 1 .. 10 loop print i;end loop;"

1

2

3

4

5

6

7

8

9

10

hplsql -f执行脚本:

测试表:

hive>select * from qf24.u5;

OK

7 yy

3 cc

2 bb

创建脚本hp.sql

create function hello(text string)

returnS string

BEGIN

RETRUEN 'Hello,' || text || '!';

END;

FOR item IN(

SELECT id,name FROM qf24.u5 limit 3

)

loop

        println item.id || '|' || item.name || '|' || hello(item.name);

end loop;

测试:

[root@hadoop01 hplsql-0.3.31]# ./hplsql -f /home/hivedata/hp.sql

7|yy|Hello,yy!

3|cc|Hello,cc!

2|bb|Hello,bb!

创建存储过程的格式:

use database;

create procedure

begin

......

end;

调用存储过程:

include path/sp name

call sp name;

案例:

创建存储过程:

use qf24;

create procedure select_u5()

begin

select * from qf24.u5;

end;

调用:

include 文件路径 (在代码文件中引入)

执行执行文件:

[root@hadoop01 hplsql-0.3.31]# ./hplsql -f /home/hivedata/ps.sql

调用指定存储过程或者方法:

[root@hadoop01 hplsql-0.3.31]# ./hplsql -f /home/hivedata/ps.sql -main select_u5

感谢你能够认真阅读完这篇文章,希望小编分享的“hive存储过程怎么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: hive存储过程怎么用

本文链接: https://www.lsjlt.com/news/228702.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • hive存储过程怎么用
    这篇文章主要介绍了hive存储过程怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。hive存储过程简介x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发...
    99+
    2023-06-02
  • 如何使用hive存储过程
    这篇文章给大家分享的是有关如何使用hive存储过程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。hive存储过程简介1.x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发时候,一般是将一段一段的...
    99+
    2023-06-02
  • Hive方便地实现存储过程是怎样的
    Hive方便地实现存储过程是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。第一种是 HPL/SQL。这种方式目前还不完善,比如游标使用限制多,很多功能无法实现,对变量...
    99+
    2023-06-03
  • MySQL5存储过程怎么用
    这篇文章主要介绍了MySQL5存储过程怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、下载、安装,不用多说(偶喜欢非安装版,解压就能...
    99+
    2024-04-02
  • db2怎么调用存储过程
    在DB2数据库中,可以使用以下步骤调用存储过程: 首先,使用CREATE PROCEDURE语句在数据库中创建存储过程。例如,创建...
    99+
    2024-04-09
    db2
  • hibernate怎么调用存储过程
    要在Hibernate中调用存储过程,您需要执行以下步骤: 创建一个实体类,该实体类映射存储过程的结果集。 在Hiberna...
    99+
    2024-04-09
    hibernate
  • 怎么调用Oracle存储过程
    这篇文章给大家介绍怎么调用Oracle存储过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Oracle的存储过程语法如下:create procedure 存储过...
    99+
    2024-04-02
  • oracle怎么调用存储过程
    要调用Oracle存储过程,可以按照以下步骤进行操作:1. 创建存储过程:在Oracle数据库中创建存储过程。可以使用PL/SQL开...
    99+
    2023-08-23
    oracle
  • sql怎么调用存储过程
    在SQL中调用存储过程可以通过以下步骤实现: 创建存储过程: 首先在数据库中创建存储过程,可以使用CREATE PROCEDURE...
    99+
    2024-04-02
  • MySQL中怎么使用存储过程
    MySQL中怎么使用存储过程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 mysql存储过程存储过程(Stored  P...
    99+
    2024-04-02
  • PLSQL怎么调用Oracle存储过程
    在PL/SQL中调用Oracle存储过程可以通过使用以下语法: DECLARE <variable_declaration...
    99+
    2024-03-05
    PLSQL Oracle
  • Java中怎么调用存储过程
    Java中怎么调用存储过程,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。存储过程是指保存在数据库并在数据库端执行的程序。你可以使用特殊的语法在Java类中调用存储过程。在调...
    99+
    2023-06-17
  • LINQ中怎么调用存储过程
    这篇文章给大家介绍LINQ中怎么调用存储过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。LINQ调用存储过程实现起来一点都不容易,就像其它的存储过程一样,需要很强的逻辑性与实用性。LINQ调用存储过程时出现的问题被c...
    99+
    2023-06-17
  • MyBatis中怎么使用存储过程
    在 MyBatis 中使用存储过程可以通过以下步骤实现: 定义存储过程:首先在数据库中定义存储过程,可以使用 SQL 来创建存储...
    99+
    2024-05-08
    MyBatis
  • mybatis怎么调用oracle存储过程
    在MyBatis中调用Oracle存储过程可以通过使用select或update语句执行存储过程的方式来实现。以下是一个示例: &l...
    99+
    2024-04-09
    mybatis oracle
  • MySQL的存储过程怎么调用
    这篇文章主要讲解了“MySQL的存储过程怎么调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的存储过程怎么调用”吧!概述由MySQL5.0 版本开始支持存储过程。如果在实现用户的...
    99+
    2023-07-02
  • navicat怎么查存储过程
    直接查询存储过程的步骤:打开 navicat,展开 "对象" 节点,选择 "存储过程"。右键单击所需存储过程,选择 "打开"。将光标置于存储过程定义开始处,按 f9 执行查询。 如何使...
    99+
    2024-04-24
    navicat
  • oracle存储过程怎么看
    有三个方法可以查看 oracle 存储过程:使用 sql*plus 执行 desc stored_procedure_name 命令。在 oracle enterprise manage...
    99+
    2024-04-19
    oracle
  • MySQL存储过程详解 mysql 存储过程
    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Proce...
    99+
    2024-04-02
  • mysql存储过程中游标怎么用
    这篇文章将为大家详细讲解有关mysql存储过程中游标怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 DELIMITER $$USE `...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作