sparkSQL、sparkDSL练习

二、行列转换

表1
姓名,科目,分数
name,item,score
张三,数学,33
张三,英语,77
李四,数学,66
李四,英语,78


表2
姓名,数学,英语
name,math,english
张三,33,77
李四,66,78

1、将表1转化成表2
2、将表2转化成表1

import org.apache.spark.sql.{Column, DataFrame, SparkSession}

object Code02 {
  def main(args: Array[String]): Unit = {
    val spark: SparkSession = SparkSession.builder()
      .master("local")
      .appName("change")
      .config("spark.sql.shuffle.partitions", 1)
      .getOrCreate()

    import org.apache.spark.sql.functions._
    import spark.implicits._

    val info1DF: DataFrame = spark
      .read
      .format("csv")
      .option("sep", ",")
      .schema("name STRING,item STRING,score INT")
      .load("data/1126/info1.txt")

    val info2DF: DataFrame = spark
      .read
      .format("csv")
      .option("sep", ",")
      .schema("name STRING,math INT,english INT")
      .load("data/1126/info2.txt")

    info1DF.show()
    info2DF.show()


    // 1、将表1转化成表2
    info1DF
      .groupBy($"name")
      .agg(
        sum(when($"item"==="数学",$"score")) as "math",
        sum(when($"item"==="英语",$"score")) as "english"
      )
      .show()

    // 2、将表2转化成表1
    val columns: Column = map(
      expr("'数学'"),$"math",
      expr("'英语'"),$"english"
    )
    info2DF
      .select($"name",explode(columns) as Array("item","score"))
      .show()



//SPARK SQL:
// 1、将表1转化成表2
    info1Df.createTempView("t1")
    spark.sql(
      """
        |SELECT name
        |,sum(case when item="数学" then score else 0 end) math
        |,sum(case when item="英语" then score else 0 end) english
        |FROM t1
        |GROUP BY name
        |""".stripMargin)
      .show()

    // 2、将表2转化成表1
    info2Df.createTempView("t2")
    spark.sql(
      """
        |SELECT name,item,score
        |FROM t2 lateral view explode(map("数学",math,"英语",english)) as item,score
        |""".stripMargin)
      .show()
  }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值