码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 5.1 Apache Hive DML语句与函数使用


    Apache Hive DML语句与函数使用

    • 一、Hive SQL DML语法之加载数据
      • 1、Hive SQL-DML-Load加载数据
        • Load语法功能
        • Load语法规则
        • 语法规则之filepath
        • 语法规则之LOCAL
        • LOCAL本地是哪里?
        • 练习:Load Data From Local FS or HDFS
      • 2、Hive SQL-DML-Insert插入数据
        • Insert语法功能
        • insert+select
    • 二、Hive SQL DML语法之查询数据
      • 1、Hive SQL select语法介绍
        • Select语法树
        • 练习
      • 2、 select_expr、ALL DISTINCT 结果返回与去重
        • ( 1)select_expr
        • (2)ALL 、DISTINCT
      • 3、WHERE 过滤
      • 3、聚合操作
      • 5、GROUP BY 分组
      • 6、HAVING 分组后过滤
      • 7、ORDER BY 排序
      • 8、LIMIT 返回条数限制
    • 三、Hive SQL Join关联查询
      • 1、Hive Join语法规则
        • inner join 内连接
        • left join 左连接
    • 四、Hive SQL中的函数使用
      • 1、 Hive 函数概述及分类标准
        • 概述
        • 分类标准
        • 用户定义函数UDF分类标准
        • UDF分类标准扩大化
      • 2、 Hive 常用的内置函数
        • 概述
        • (1)String Functions 字符串函数
        • (2)Date Functions 日期函数
        • (3)Mathematical Functions 数学函数
        • (4)Conditional Functions 条件函数

    一、Hive SQL DML语法之加载数据

    1、Hive SQL-DML-Load加载数据

    回顾

    • 在Hive中建表成功之后,就会在HDFS上创建一个与之对应的文件夹,且文件夹名字就是表名;
    • 文件夹父路径是由参数hive.metastore.warehouse.dir控制,默认值是/user/hive/warehouse;
      在这里插入图片描述
    • 不管路径在哪里,只有把数据文件移动到对应的表文件夹下面,Hive才能映射解析成功;
    • 最原始暴力的方式就是使用hadoop fs –put|-mv等方式直接将数据移动到表文件夹下;
    • 但是,Hive官方推荐使用Load命令将数据加载到表中
      在这里插入图片描述

    Load语法功能

    • Load英文单词的含义为:加载、装载;
    • 所谓加载是指:将数据文件移动到与Hive表对应的位置,移动时是纯复制、移动操作。
    • 纯复制、移动指在数据load加载到表中时,Hive不会对表中的数据内容进行任何转换,任何操作

    Load语法规则

    LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename;
    
    • 1

    语法规则之filepath

    • filepath表示待移动数据的路径。可以指向文件(在这种情况下,Hive将文件移动到表中),也可以指向目录(在这种情况下,Hive将把该目录中的所有文件移动到表中)。
    • filepath文件路径支持下面三种形式,要结合LOCAL关键字一起考虑:
    1. 相对路径,例如:project/data1
    2. 绝对路径,例如:/user/hive/project/data1
    3. 具有schema的完整URI,例如:hdfs://namenode:9000/user/hive/project/data1

    语法规则之LOCAL

    • 指定LOCAL, 将在本地文件系统中查找文件路径。
      若指定相对路径,将相对于用户的当前工作目录进行解释;
      用户也可以为本地文件指定完整的URI-例如:file:///user/hive/project/data1。
    • 没有指定LOCAL关键字。
      如果filepath指向的是一个完整的URI,会直接使用这个URI;
      如果没有指定schema,Hive会使用在hadoop配置文件中参数fs.default.name指定的(不出意外,都是HDFS)

    LOCAL本地是哪里?

    • 如果对HiveServer2服务运行此命令
      本地文件系统指的是Hiveserver2服务所在机器的本地Linux文件系统,不是Hive客户端所在的本地文件系统。
      在这里插入图片描述

    练习:Load Data From Local FS or HDFS

    Step1:建表

    --step1:建表
    --建表student_local 用于演示从本地加载数据
    create table student_local(num int,name string,sex string,age int,dept string) row format delimited fields terminated by ',';
    --建表student_HDFS 用于演示从HDFS加载数据
    create external table student_HDFS(num int,name string,sex string,age int,dept string) row format delimited fields terminated by ',';
    
    • 1
    • 2
    • 3
    • 4
    • 5

    Step2:load加载数据

    --建议使用beeline客户端 可以显示出加载过程日志信息
    --step2:加载数据
    -- 从本地加载数据 数据位于HS2(node1)本地文件系统 本质是hadoop fs -put上传操作
    LOAD DATA LOCAL INPATH '/root/hivedata/students.txt' INTO TABLE student_local;
    --从HDFS加载数据 数据位于HDFS文件系统根目录下 本质是hadoop fs -mv 移动操作
    --先把数据上传到HDFS上 hadoop fs -put /root/hivedata/students.txt /
    LOAD DATA INPATH '/students.txt' INTO TABLE student_HDFS;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    加载数据日志信息
    在这里插入图片描述

    2、Hive SQL-DML-Insert插入数据

    Insert语法功能

    • Hive官方推荐加载数据的方式:
      清洗数据成为结构化文件,再使用Load语法加载数据到表中。这样的效率更高。
    • 也可以使用insert语法把数据插入到指定的表中,最常用的配合是把查询返回的结果插入到另一张表中。

    insert+select

    • insert+select表示:将后面查询返回的结果作为内容插入到指定表中。
    1. 需要保证查询结果列的数目和需要插入数据表格的列数目一致。
    2. 如果查询出来的数据类型和插入表格对应的列数据类型不一致,将会进行转换,但是不能保证转换一定成功,转换失败的数据将会为NULL。
    INSERT INTO TABLE tablename select_statement1 FROM from_statement;
    
    • 1
    --step1:创建一张源表student
    drop table if exists student;
    create table student(num int,name string,sex string,age int,dept string)
    row format delimited
    fields terminated by ',';
    --加载数据
    load data local inpath '/root/hivedata/students.txt' into table student;
    --step2:创建一张目标表 只有两个字段
    create table student_from_insert(sno int,sname string);
    --使用insert+select插入数据到新表
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
  • 相关阅读:
    LeetCode59.螺旋矩阵
    Oracle-索引
    Linux安装GCC(最新版)
    RabbitMQ之集群方案原理
    线程安全(六)AQS 的工作原理
    Go语言函数底层实现
    SpringBoot + 自定义注解,实现用户操作日志(支持SpEL表达式)
    使用 GitHub Actions 编译和发布 Android APK
    面向对象的编程语言是什么意思?——跟老吕学Python编程
    南大通用数据库-Gbase-8a-学习-22-备份恢复工具gcrcman
  • 原文地址:https://blog.csdn.net/qq_40947195/article/details/127740934
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号