百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

三十五、SparkSQL: RDD、DataFrame和Dataset的关系

liuian 2025-07-27 22:00 10 浏览

在SparkSQL中,在Spark1.3版本时为SparkSQL提供了一种新的数据集结构DataFrame, 而从Spark1.6开始提供了一种新的弹性的、懒执行的、分布式的抽象数据集Dataset,那么它与RDD之前有着什么样的关联呢?

来看看源码中的介绍:


1.RDD、DataFrame和Dataset

  • RDD
    • RDD是一个弹性的、可容错的分布式的数据集,在Spark中是最基本的抽象,它代表一个不可变的,可并行化操作的分区集合。
    • RDD提供了基本的转换操作,比如map, filter等算子。
    • RDD有五大特性:
      • RDD由一系列分区组成
      • 提供了方法、操作作用于于每一个split
      • RDD之间有依赖关系
      • 分区器是作用于key-value格式的RDD上
      • 为每个split,提供了最佳的计算位置信息
  • DataFrame
    • DataFrame也是一个弹性的,分布式的,懒执行的抽象的数据集容器。
    • DataFrame更像传数据库中的二维表,除了存储数据的计算逻辑外,它还记录了数据的结构信息,即schema。
    • 与Hive类似,DataFrame也支持嵌套数据类型,如struct, array和map。
    • DataFrame的API提供了一套高层的关系操作,主要用来处理结构化的数据。
  • Dataset
    • Dataset也是一种分布式的数据集合,在Spark1.6版本中引入 ,是DataFrame API的扩展,它提供了类型安全的(type-safe)、面向对象的编程接口,Dataset利用Catalyst的优化器可以让用户通过lambda表达式的方式对数据进行查询和操作。
    • 在Spark2.0以后,为了方便开发者,Spark将DataFrame和Dataset的API进行了整合,为用户提供了一套标准的丰富的API。
    • 在Scala中,DataFrame = Dataset[Row]
    • Dataset其实是对RDD的更高层的封装,每个切片上也会有对应的算子作用于分区上
    • Dataset支持更加智能的数据源,如jdbc, json, parquet等。

2.RDD、DataFrame和Dataset三者之间的关系

  • RDD和DataFrame最主要的区别在于DataFrame面向的是结构化的数据,而RDD即可以是非结构化的数据也可以是非结构化的数据。
  • DataFrame内部除了存储数据的计算逻辑,还存储了明确的元数据schema信息,即列的名称、类型、是否为空等信息,这样带来的好处是可以减少数据读取以有更好地优化执行计划,从而保证查询的效率。
  • 上面图中直观地描述了DataFrame和RDD的区别
    • RDD中虽然以Person作为类型参数,但是Spark框架不了解Person的内部结构
    • DataFrame中提供了详细的结构信息,有列名,列的类型,SparkSQL中可以清楚地知道它包含哪些元数据信息,即所谓的schema信息;
    • DataFrame是分布式的Row对象的集合,DataFrame底层有catalyst优化生成器,可生成执行计划,比如谓词下推、列裁剪等。
  • Dataset和DataFrame的关系
    • Dataset也是分布式的数据集,它集成了RDD和DataFrame的优点,在Scala和Java的API中提供了丰富的lambda函数。
    • Spark 2.0以后,为了方便开发者,Spark将DataFrame和Dataset的API进行了整合,提供了结构化的API,用户可通过一套标准的API就能完成两者的操作。
    • 其实,在Scala中, DataFrame就是Dataset[Row], 即Dataset存放了Row类型的数据, 二者的关系如下图:

3.Untyped的DataFrame和Typed的Dataset

在SparkSQL中,DataFrame的API被标记为Untyped API, 而Dataset API被标记为Typed API。其中,DataFrame的Untyped是相对于语言或API层面,它确实有明确的schema信息,但是这些信息完全由Spark维护,Spark只会在实际运行时检查这些类型的一致性。


Spark2.0版本以后,官方重新更新了API: type DataFrame = Dataset[Row], 即DataFrame是存放了Row类型的Dataset, 其中的Row是Spark中定义的一个特质特性trait, 实现Row的子类中封装了schema信息。


而Dataset被标记为Typed的强类型,实质上,Dataset的类型由scala中的样例类或者Java中的Java Bean来明确指定,例如:

case class Animal(name:String, age: Int)
val animalDs: Dataset[Animal] = session.read.json("animal.json").as[Animal]


4.RDD, DataFrame和Dataset使用总结

  • RDD是Spark偏底层的API, 适合非结构化数据的处理,而Dataset和DataFrame更适合结构化数据和半结构化数据的处理;
  • DataFrame和Dataset可以通过统一的Structured API进行访问,而RDD则更适合函数式编程的场景;
  • 相比于DataFrame而言,Dataset是强类型的, 有着更为严格的静态的类型检查;
  • Dataset、DataFrame、SQL的底层都依赖于RDD API, 并对外提供结构化的访问接口;

相关推荐

10种常见的MySQL错误,你可中招?

【51CTO.com快译】如果未能对MySQL8进行恰当的配置,您非但可能遇到无法顺利访问、或调用MySQL的窘境,而且还可能给真实的应用生产环境带来巨大的影响。本文列举了十种MySQL...

MySQL主从如何保证数据一致性

MySQL主从(主备)搭建请点击基于Spring的数据库读写分离。MySQL主备基本原理假设主备切换前,我们的主库是节点A,节点B是节点A的备库,客户端的读写都是直接访问节点A,节点B只是将A的更新同...

MySQL低版本升级操作流程

(关注“数据库架构师”公众号,提升数据库技能,助力职业发展)0-升级背景MySQL5.5发布于2010年,至今已有十年历史,官方已经停止更新。2008年发布的MySQL5.1版本,在2018年...

MySQL数据库知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

Mysql 8.4数据库安装、新建用户和数据库、表单

1、下载MySQL数据库yuminstall-ywgetperlnet-toolslibtirpc#安装wget和perl、net-tools、libtirpcwgethtt...

mysql8.0新功能介绍

MySQL8.0新特性集锦一、默认字符集由latin1变为utf8mb4在8.0版本之前,默认字符集为latin1,utf8指向的是utf8mb3,8.0版本默认字符集为utf8mb4,utf8默...

全网最详细解决Windows下Mysql数据库安装后忘记初始root 密码方法

一、准备重置root的初始化密码Win+R键启动命令输入窗口;输入cmd打开命令执行窗口;##界面如下##输入命令:netstopmysqld#此操作会停止当前运行的...

互联网大厂面试:MySQL使用grant授权后必须flush privilege吗

从我上大学时,数据库概论老师就告诉我,MySQL使用grant对用户授权之后,一定记得要用flushprivilege命令刷新缓存,这样才能使赋权命令生效。毕业工作以后,在很多的技术文档上,仍然可以...

# mysql 8.0 版本无法使用 sqlyog 等图形界面 登录 的解决方法

30万以下的理想L6来了##mysql8.0版本无法使用sqlyog等图形界面登录的解决方法当我们在cmd下登录mysql时正常时,用sqlyog等图形界面连接数据库时却...

MySQL触发器介绍

前言:在学习MySQL的过程中,可能你了解过触发器的概念,不清楚各位是否有详细的去学习过触发器,最近看了几篇关于触发器的文档,分享下MySQL触发器相关知识。1.触发器简介触发器即trigg...

管理员常用的MySQL命令汇总(一)

以下是管理员常用的MySQL命令:以管理员身份连接到MySQL:mysql-uroot-p创建新的MySQL用户:CREATEUSER'username'@'...

Linux(CentOS) 在线安装MySQL8.0和其他版本,修改root密码

一:安装MySQL数据库1),下载并安装MySQL官方的YumRepositorymysql官方仓库地址:https://dev.mysql.com/downloads/repo/yum/选择自...

解决 MySQL 8.0 一直拒绝 root 登录问题

Accessdeniedforuser'root'@'localhost'(usingpassword:YES)这个错误在网上搜一下,能看到非常多的此类...

大模型MCP之MYSQL安装

前言学习大模型的时候需要一个mysql,原因还是在公司使用电脑的时候不允许按照Docker-Desktop,我的宿主机其实是MAC,我习惯上还是在centsos上面安装,就发现这件过去很简单的事情居然...

MySQL ERROR 1396

ERROR1396(HY000):OperationCREATEUSERfailedfor'usera'@'%'问题描述mysql>create...