2020-11-11--Spark编程基础(Scala版)第6章 Spark SQL

本文介绍了Spark SQL的发展历程,重点讲解了DataFrame的概念和重要性,如何从RDD转换为DataFrame,以及DataFrame的创建、保存和常用操作。Spark SQL因兼容HiveQL、提供DataFrame API和高性能而成为大数据分析的重要工具。
摘要由CSDN通过智能技术生成

6.1 Spark SQL简介

6.1.1 从Shark说起

在这里插入图片描述
在这里插入图片描述
Shark即Hive on Spark,为了实现与Hive兼容,Shark在HiveQL方面重用了Hive中HiveQL的解析、逻辑执行计划翻译、执行计划优化等逻辑,可以近似认为仅将物理执行计划从MapReduce作业替换成了Spark作业,通过Hive的HiveQL解析,把HiveQL翻译成Spark上的RDD操作
Shark的出现,使得SQL-on-Hadoop的性能比Hive有了10-100倍的提高
在这里插入图片描述

Shark的设计导致了两个问题

一是执行计划优化完全依赖于Hive,不方便添加新的优化策略
二是因为Spark是线程级并行,而MapReduce是进程级并行,因此,Spark在兼容Hive的实现上存在线程安全问题,导致Shark不得不使用另外一套独立维护的打了补丁的Hive源码分支
2014年6月1日Shark项目和Spark SQL项目的主持人Reynold Xin宣布:停止对Shark的开发,团队将所有资源放在Spark SQL项目上,至此,Shark的发展画上了句话,但也因此发展出两个直线:Spark SQL和Hive on Spark
在这里插入图片描述
Spark SQL作为Spark生态的一员继续发展,而不再受限于Hive,只是兼容Hive
Hive on Spark是一个Hive的发展计划,该计划将Spark作为Hive的底层引擎之一,也就是说,Hive将不再受限于一个引擎,可以采用Map-Reduce、Tez、Spark等引擎

6.1.2 Spark SQL设计

Spark SQL在Hive兼容层面仅依赖HiveQL解析、Hive元数据,也就是说,从HQL被解析成抽象语法树(AST)起,就全部由Spark SQL接管了。Spark SQL执行计划生成和优化都由Catalyst(函数式关系查询优化框架)负责
在这里插入图片描述
Spark SQL增加了DataFrame(即带有Schema信息的RDD),使用户可以在Spark SQL中执行SQL语句,数据既可以来自RDD,也可以是Hive、HDFS、Cassandra等外部数据源,还可以是JSON格式的数据
Spark SQL目前支持Scala、Java、Python三种语言,支持SQL-92规范
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.1.3 为什么推出Spark SQL

关系数据库已经很流行
关系数据库在大数据时代已经不能满足要求
首先,用户需要从不同数据源执行各种操作,包括结构化、半结构化和非结构化数据
其次,用户需要执行高级分析,比如机器学习和图像处理
在实际大数据应用中,经常需要融合关系查询和复杂分析算法(比如机器学习或图像处理),但是,缺少这样的系统
Spark SQL填补了这个鸿沟:
首先,可以提供DataFrame API,可以对内部和外部各种数据源执行各种关系型操作
其次,可以支持大数据中的大量数据源和数据分析算法
Spark SQL可以融合:传统关系数据库的结构化数据管理能力和机器学习算法的数据处理能力

6.2 DataFrame概述

DataFrame的推出,让Spark具备了处理大规模结构化数据的能力,不仅比原有的RDD转化方式更加简单易用,而且获得了更高的计算性能
Spark能够轻松实现从MySQL到DataFrame的转化,并且支持SQL查询
在这里插入图片描述
图 DataFrame与RDD的区别
RDD是分布式的 Java对象的集合,但是,对象内部结构对于RDD而言却是不可知的
DataFrame是一种以RDD为基础的分布式数据集,提供了详细的结构信息

6.3 DataFrame的创建

从Spark2.0以上版本开始,Spark使用全新的SparkSession接口替代Spark1.6中的SQLContext及HiveContext接口来实现其对数据加载、转换、处理等功能。SparkSession实现了SQLContext及HiveContext所有功能
SparkSession支持从不同的数据源加载数据,并把数据转换成DataFrame,并且支持把DataFrame转换成SQLContext自身中的表,然后使用SQL语句来操作数据。SparkSession亦提供了HiveQL以及其他依赖于Hive的功能的支持
可以通过如下语句创建一个SparkSession对象:

// An highlighted block
scala> import org.apache.spark.sql.SparkSession
scala> val spark=SparkSession.builder().getOrCreate()

在创建DataFrame之前,为了支持RDD转换为DataFrame及后续的SQL操作,需要通过import语句(即import spark.implicits._)导入相应的包,启用隐式转换。
在创建DataFrame时,可以使用spark.read操作,从不同类型的文件中加载数据创建DataFrame,例如:
spark.read.json(“people.json”):读取people.json文件创建DataFrame;在读取本地文件或HDFS文件时,要注意给出正确的文件路径;
spark.read.parquet(“people.parquet”):读取people.parquet文件创建DataFrame;
spark.read.csv(“people.csv”):读取people.csv文件创建DataFrame。
一个实例
在“/usr/local/spark/examples/src/main/resources/”这个目录下,这个目录下有两个样例数据people.json和people.txt。people.json文件的内容如下:
{“name”:“Michael”}
{“name”:“Andy”, “age”:30}
{“name”:“Justin”, “age”:19}
people.txt文件的内容如下
Michael, 29
Andy, 30
Justin, 19

// An highlighted block
scala> import org.apache.spark.sql.SparkSession
import org.apache.spark.sql.SparkSession
 
scala> val spark=SparkSession.builder().getOrCreate()
spark: org.
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很高兴为您回复。Spark SQLSpark生态系统中的一个模块,它提供了一种基于结构化数据的编程接口。Spark SQL支持多种数据源,包括Hive表、Parquet文件、JSON文件等。在Spark SQL中,可以使用SQL语句或DataFrame API来查询和操作数据。Spark SQL还支持用户自定义函数(UDF)和聚合函数(UDAF),可以方便地扩展功能。在Scala中,可以使用SparkSession对象来创建Spark SQL应用程序。SparkSession提供了许多方法来读取和写入数据,以及执行SQL查询。Spark SQL还支持分布式执行,可以在集群中处理大规模数据。 ### 回答2: Spark SQLSpark 对结构化数据处理的一个模块,它提供了一个分布式 SQL 引擎,并支持从多个数据源中读取并处理数据。ScalaSpark 支持的编程语言之一,它提供了强大的函数式编程特性,可以方便地处理大数据量。在本中,我们将探讨如何使用 Spark SQL 进行结构化数据处理。 一、Spark SQL的概念 Spark SQL 是基于 DataFrame 的 SQL 引擎,它能够将多种数据源转换为 DataFrame,并通过 SQL 或者 DataFrame API 进行数据操作与分析。Spark SQL 支持的数据源包括 Hive 表、Parquet、JSON、CSV、JDBC 等多种格式。Spark SQL 可以与所有 Spark 生态工具进行集成,例如 Spark MLlib、GraphX 等。 二、Spark SQL的特性 1. 高性能引擎 Spark SQL 可以利用 Spark 的分布式计算模型,在大规模数据处理时显著提高性能。相比于传统的 SQL 引擎,Spark SQL 采用了列式存储,减少了 I/O 操作,能够更快地完成数据的处理与分析。 2. 强大的数据源支持 Spark SQL 支持读取多种数据源,包括 Hive 表、Parquet、JSON、CSV、JDBC 等多种格式。同时,Spark SQL 也支持将数据导出为多种格式,例如 Parquet、JSON、CSV 等。 3. 兼容性强 Spark SQL 支持 ANSI SQL 标准,所以能够与大部分 SQL 工具进行兼容。同时,Spark SQL 还支持使用 HiveQL 进行查询,可以兼容 Hive 的语法。 4. 常用的操作函数 Spark SQL 提供了一些常用的操作函数,例如 avg、sum、count、min、max 等,方便进行数据处理与分析。 三、Spark SQL的使用 Spark SQL 的使用主要可以分为三个步骤: 1. 将数据源转换为 DataFrame Spark SQL 支持读取多种数据源,通过调用相应的读取 API,可以将数据源读取为 DataFrame。 val df = spark.read.json("file:///path/to/json") 2. 执行 SQL 查询 Spark SQL 支持执行 ANSI SQL 标准的查询,通过调用 DataFrame 的 sql 方法,可以执行 SQL 查询。 df.createOrReplaceTempView("people") val result = spark.sql("SELECT name, age FROM people WHERE age > 20") 3. 将结果导出为数据源 Spark SQL 支持将查询结果导出为多种格式,例如 Parquet、JSON、CSV 等。 result.write.parquet("file:///path/to/parquet") result.write.json("file:///path/to/json") 总之,Spark SQL 是一个高效、强大、兼容性强的 SQL 引擎,在大规模数据处理场景下具有很好的应用价值。熟练掌握 Spark SQL 的 API 和实战技巧,能够有效地提高工作效率和数据分析能力。 ### 回答3: Spark SQL是一种分布式数据处理引擎,它是Apache Spark的一个模块,提供了一种更高层次的数据处理方式,通过Spark SQL可以使用SQL语句对数据进行查询、过滤和统计等操作,同时spark SQL还包含DataFrame和DataSet两种API,可以很方便地进行RDD与SQL之间的数据转换。 一、DataFrame DataFrame是一种以表格形式表示的分布式数据集,它与关系型数据库中的表非常相似,每行数据有一个相同的结构,每列数据都有一个名称并且数据类型相同,通过DataFrame可以很方便地进行数据的查询、过滤和聚合等操作。可以使用类似SQL的语法对DataFrame进行查询,对于DataFrame内部元素的类型,Spark SQL支持基本数据类型,数组和结构体,还支持通过UDF在数据集中添加新列。同时,DataFrame的数据可以很方便地转换为RDD进行复杂的计算。 二、DataSet DataSet是一个分布式的数据集,与DataFrame类似,但是它具有类型参数化的特性,并支持更多的编译时检查。由于有了类型参数化的特性,DataSet可以支持更多的面向对象的操作,可以对DataSet进行面向对象的映射、过滤和聚合等操作。 三、Spark SQL使用 Spark SQL使用非常简单,首先需要构建SparkSession对象,SparkSession是DataFrame和DataSet的创建入口,可以使用它来读取数据、创建数据集、执行SQL查询等操作。 SparkSession支持不同的数据源,包括Hadoop的文件系统,Hive表和外部数据源等,可以使用SparkSession.read方法读取数据,并将其转换为DataFrame或DataSet类型。在使用Spark SQL进行数据分析时,可以使用spark.sql方法执行SQL语句,API提供了大量的操作函数,能够对DataFrame或DataSet进行过滤、聚合和操作等操作,在复杂数据处理中非常实用。 总的来说,Spark SQL是Apache Spark的一个重要模块,提供了一种简单、高效的分布式数据处理方式,它的DataFrame和DataSet API可以很方便地对大量数据进行查询和分析,并且相比于RDD更容易理解和操作。通过Spark SQL可以有效地处理和分析海量数据,并为实现机器学习、深度学习和数据挖掘等应用提供了强有力的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值