SparkSQL

什么是Spark SQL
Spark SQL是Spark用来处理结构化数据的一个模块,它提供了2个编程抽象:DataFrame和DataSet,并且作为分布式SQL查询引擎的作用.
我们已经学习了Hive,它是将Hive SQL转换成MapReduce然后提交到集群上执行,大大简化了编写MapReduce的程序的复杂性,由于MapReduce这种计算模型执行效率比较慢,所以Spark SQL应用而生,它是将Spark SQL转换成RDD,然后提交到集群执行,执行效率非常快!
Spark SQL的特点

  • 易整合
  • 统一的数据访问方式
  • 兼容Hive
  • 标准的数据连接

什么是DataFrame
与RDD类似,DataFrame也是一个分布式数据容器.然而DataFrame更像传统数据库的二维表格,除了数据以外,还记录数据的结构信息,即schema.同时,与Hive类似,DataFrame也支持嵌套数据类型(struct/array/map).

什么是DataSet

  • 是DataFrame API的一个扩展,是Spark最新的数据抽象.
  • 用户友好的API风格,既具有类型安全检查也具有Dataframe的查询优化特性.
  • Dataset支持编解码器,当需要访问非堆上的数据时可以避免反序列化整个对象,提高效率.
  • 样例类被用来在Dataset中定义数据的结构信息,样例类中每个属性的名称直接映射到DataSet中的字段名称.
  • Dataframe是Dataset的特例,DataFrame=Dataset[Row],所以可以通过as方法将Dataframe转换为Dataset.Row是一个类型,跟Car/Person这些的类型一样,所有的表结构信息都用Row来表示.
  • DataSet是强类型的. eg:Dataset[Car],Dataset[Person]
  • DataFrame只是知道字段,但是不知道字段的类型,所以在执行这些操作的时候是没办法在编译的时候检查是否类型失败的,eg:你可以对一个String进行减法操作,在执行的时候才报错.而DataSet不仅仅知道字段,而且知道字段类型,所以有更严格的错误检查.就跟JSON对象和类对象之间的类比.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯子@123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值