首页
学习
活动
专区
圈层
工具
发布

Spark SQL

一、Spark SQL简介 (一)从Shark说起 Hive是一个基于Hadoop 的数据仓库工具,提供了类似于关系数据库SQL的查询语言HiveQL,用户可以通过HiveQL语句快速实现简单的...Spark SQL增加了DataFrame(即带有Schema信息的RDD),使用户可以在Spark SQL中执行SQL语句,数据既可以来自RDD,也可以是Hive、HDFS、Cassandra等外部数据源...Spark SQL填补了这个鸿沟: 首先,可以提供DataFrame API,可以对内部和外部各种数据源执行各种关系型操作 其次,可以支持大数据中的大量数据源和数据分析算法 Spark SQL可以融合:...三、DataFrame的创建 从Spark2.0以上版本开始,Spark使用全新的SparkSession接口替代Spark1.6中的SQLContext及HiveContext接口来实现其对数据加载...SparkSession支持从不同的数据源加载数据,并把数据转换成DataFrame,并且支持把DataFrame转换成SQLContext自身中的表,然后使用SQL语句来操作数据。

1.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Shark,Spark SQL,Spark上的Hive以及Apache Spark上的SQL的未来

    许多人认为SQL的交互性需要(即EDW)构建的昂贵的专用运行时为其的查询处理。Shark成为Hadoop系统中第一个交互式SQL,是唯一一个基于一般运行时(Spark)构建的。...由于企业正在寻找能在企业环境中给予他们优势的方法,正在采用超越SQL提供的简单的汇总和向下钻取功能的技术。...对于SQL用户,Spark SQL提供了最先进的SQL性能并保持与Shark / Hive的兼容性。...有了将在Apache Spark 1.1.0中引入的功能,Spark SQL在TPC-DS性能上击败Shark几乎一个数量级。...我们会努力工作,将在接下来的几个版本中为您带来更多体验。对于具有传统Hive部署的组织,Hive on Spark将为他们提供一条清晰的Spark路径。

    1.8K20

    Spark系列 - (3) Spark SQL

    为了实现与Hive兼容,Shark在HiveQL方面重用了Hive中HiveQL的解析、逻辑执行计划、执行计划优化等逻辑;可以近似认为仅将物理执行计划从MapReduce作业替换成了Spark作业,通过...Spark SQL作为Spark生态的一员诞生,不再受限于Hive,只是兼容Hive。...可以把它当做数据库中的一张表来对待,DataFrame也是懒执行的。性能上比 RDD 要高,主要原因:优化的执行计划:查询计划通过 Spark catalyst optimiser 进行优化。...3.3 Spark SQL优化 Catalyst是spark sql的核心,是一套针对spark sql 语句执行过程中的查询优化框架。...因此要理解spark sql的执行流程,理解Catalyst的工作流程是理解spark sql的关键。而说到Catalyst,就必须提到下面这张图了,这张图描述了spark sql执行的全流程。

    1.5K10

    Spark SQL JOIN

    一、 数据准备 本文主要介绍 Spark SQL 的多表连接,需要预先准备测试数据。...其中内,外连接,笛卡尔积均与普通关系型数据库中的相同,如下图所示: 这里解释一下左半连接和左反连接,这两个连接等价于关系型数据库中的 IN 和 NOT IN 字句: -- LEFT SEMI JOIN...("SELECT * FROM emp CROSS JOIN dept ON emp.deptno = dept.deptno").show() 2.8 NATURAL JOIN 自然连接是在两张表中寻找那些数据类型和列名都相同的字段...spark.sql("SELECT * FROM emp NATURAL JOIN dept").show() 以下是一个自然连接的查询结果,程序自动推断出使用两张表都存在的 dept 列进行连接,其实际等价于...: spark.sql("SELECT * FROM emp JOIN dept ON emp.deptno = dept.deptno").show() 由于自然连接常常会产生不可预期的结果,所以并不推荐使用

    1.1K20

    Spark SQL 快速入门系列(8) | | Hive与Spark SQL的读写操作

    需要强调的一点是,如果要在 Spark SQL 中包含Hive 的库,并不需要事先安装 Hive。一般来说,最好还是在编译Spark SQL时引入Hive支持,这样就可以使用这些特性了。...若要把 Spark SQL 连接到一个部署好的 Hive 上,你必须把 hive-site.xml 复制到 Spark的配置文件目录中($SPARK_HOME/conf)。...需要注意的是,如果你没有部署好Hive,Spark SQL 会在当前的工作目录中创建出自己的 Hive 元数据仓库,叫作 metastore_db。...Hive 的元数据存储在 derby 中, 仓库地址:$SPARK_HOME/spark-warehouse ?   然而在实际使用中, 几乎没有任何人会使用内置的 Hive 二....3.2 从hive中写数据 3.2.1 使用hive的insert语句去写 3.2.1.1 写入数据(默认保存到本地) 1.源码 package com.buwenbuhuo.spark.sql.day02

    4.7K10

    Spark Sql系统入门4:spark应用程序中使用spark sql

    问题导读 1.你认为如何初始化spark sql? 2.不同的语言,实现方式都是什么? 3.spark sql语句如何实现在应用程序中使用?...为了使用spark sql,我们构建HiveContext (或则SQLContext 那些想要的精简版)基于我们的SparkContext.这个context 提供额外的函数为查询和整合spark sql..._,像我们这样做SparkContext,获取访问implicits.这些implicits用来转换rdds,带着需要的type信息到spark sql的序列化rdds为查询。...相反,一旦我们有了结构化HiveContext实例化,我们可以导入 implicits 在例子2中。导入Java和Python在例子3和4中。...基本查询例子 为了对一个表查询,我们调用HiveContext或则SQLContext的sql()函数.第一个事情,我们需要告诉spark sql关于一些数据的查询。

    1.7K70

    Spark SQL中对Json支持的详细介绍

    Spark SQL中对Json支持的详细介绍 在这篇文章中,我将介绍一下Spark SQL对Json的支持,这个特性是Databricks的开发者们的努力结果,它的目的就是在Spark中使得查询和创建JSON...而Spark SQL中对JSON数据的支持极大地简化了使用JSON数据的终端的相关工作,Spark SQL对JSON数据的支持是从1.1版本开始发布,并且在Spark 1.2版本中进行了加强。...SQL中对JSON的支持 Spark SQL提供了内置的语法来查询这些JSON数据,并且在读写过程中自动地推断出JSON数据的模式。...Spark SQL可以解析出JSON数据中嵌套的字段,并且允许用户直接访问这些字段,而不需要任何显示的转换操作。...JSON数据集 为了能够在Spark SQL中查询到JSON数据集,唯一需要注意的地方就是指定这些JSON数据存储的位置。

    5.2K90

    Spark SQL 整体介绍

    tree,在解析的过程中还会检查我们的sql语法是否有错误,比如缺少指标字段、数据库中不包含这张数据表等。...Spark SQL核心—Catalyst查询编译器 Spark SQL的核心是一个叫做Catalyst的查询编译器,它将用户程序中的SQL/Dataset/DataFrame经过一系列操作,最终转化为Spark...将SQL/Dataset/DataFrame转化成一棵未经解析(Unresolved)的树,在Spark中称为逻辑计划(Logical Plan),它是用户程序的一种抽象。...此外,Spark SQL中还有一个基于成本的优化器(Cost-based Optmizer),是由DLI内部开发并贡献给开源社区的重要组件。该优化器可以基于数据分布情况,自动生成最优的计划。...Spark SQL运行架构 sparksql 整体模块.png TreeNode 逻辑计划、表达式等都可以用tree来表示,它只是在内存中维护,并不会进行磁盘的持久化,分析器和优化器对树的修改只是替换已有节点

    37310

    Spark Sql 详细介绍

    DataSet是在Spark1.6中添加的新的接口。它集中了RDD的优点(强类型和可以用强大lambda函数)以及Spark SQL优化的执行引擎。...DataFrame     DataSet包含了DataFrame的功能,Spark2.0中两者统一,DataFrame表示为DataSet[Row],即DataSet的子集。 3....SparkSql 与Hive的整合     Spark SQL可以通过Hive metastore获取Hive表的元数据     Spark SQL自己也可创建元数据库,并不一定要依赖hive创建元数据库...,所以不需要一定启动hive,只要有元数据库,Spark SQL就可以使用。...当没有配置hive-site.xml时,Spark会自动在当前应用目录创建metastore_db和创建由spark.sql.warehouse.dir配置的目录,如果没有配置,默认是当前应用目录下的spark-warehouse

    39610

    Spark SQL 中的array类的函数例子

    需求背景:在理财 APP 中,素材、广告位、产品、策略有时候是多对多的关系。比如,在内容中台,一个素材可能关联理财、基金、存款某些产品,那我们统计该素材的好不好,转化率好不好,该归属于哪些业务?...在https://community.cloud.databricks.com/ 上创建表的方法,可以参考文档,https://docs.databricks.com/sql/language-manual...-- STRING_AGG 函数是 SQL:2016 标准中新增的函数,不是所有的数据库管理系统都支持该函数。...-- Spark 3.0 中,STRING_AGG 函数被引入作为 SQL:2016 标准的一部分。你可以使用 STRING_AGG 函数将每个分组的数据拼接成一个字符串。...,查询选修数据的同学的所有选修课程,结果中的选修课程是数组类型-- 创建表的第二种形式,student_copy 是create table student_copy as select name, collect_list

    98111

    Spark Sql 源码剖析(一):sql 执行的主要流程

    本文基于 Spark 2.1,其他版本实现可能会有所不同 之前写过不少 Spark Core、Spark Streaming 相关的文章,但使用更广泛的 Spark Sql 倒是极少,恰好最近工作中使用到了...,便开始研读相关的源码以及写相应的文章,这篇便作为 Spark Sql 系列文章的第一篇。...既然是第一篇,那么就来说说在 Spark Sql 中一条 sql 语句的主要执行流程,来看看下面这个简单的例子: val spark = SparkSession .builder() .appName...这个过程最重要的产物 unresolved logical plan 被存放在 sqlDataFrame.queryExecution 中,即 sqlDataFrame.queryExecution.logical...这篇文章是一片相对宏观的整体流程的分析,目的有二: 一是说清楚 Spark Sql 中一条 sql 语句的执行会经过哪几个核心的流程,各个核心流程大概做了什么 二是这里指出的各个核心流程也是接下来进一步进行分析学习的方向

    2.3K10
    领券