亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SparkSQL如何運用

發布時間:2022-03-30 14:10:36 來源:億速云 閱讀:112 作者:iii 欄目:開發技術

今天小編給大家分享一下SparkSQL如何運用的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

    一:SparkSQL

    1.SparkSQL簡介

    Spark SQL是Spark的一個模塊,用于處理結構化的數據,它提供了一個數據抽象DataFrame(最核心的編程抽象就是DataFrame),并且SparkSQL作為分布式SQL查詢引擎。
    Spark SQL就是將SQL轉換成一個任務,提交到集群上運行,類似于Hive的執行方式。

    2.SparkSQL運行原理

    將Spark SQL轉化為RDD,然后提交到集群執行。

    3.SparkSQL特點

    (1)容易整合,Spark SQL已經集成在Spark中

    (2)提供了統一的數據訪問方式:JSON、CSV、JDBC、Parquet等都是使用統一的方式進行訪問

    (3)兼容 Hive

    (4)標準的數據連接:JDBC、ODBC

    二、SparkSQL運用

    SparkSQL如何運用

    package sql
    
    import org.apache.avro.ipc.specific.Person
    import org.apache.spark
    import org.apache.spark.rdd.RDD
    import org.apache.spark.sql
    import org.apache.spark.sql.catalyst.InternalRow
    import org.apache.spark.sql.{DataFrame, Dataset, Row, SparkSession}
    import org.junit.Test
    
    class Intro {
      @Test
      def dsIntro(): Unit ={
        val spark: SparkSession = new sql.SparkSession.Builder()
          .appName("ds intro")
          .master("local[6]")
          .getOrCreate()
    
        //導入隱算是shi轉換
        import spark.implicits._
    
        val sourceRDD: RDD[Person] =spark.sparkContext.parallelize(Seq(Person("張三",10),Person("李四",15)))
        val personDS: Dataset[Person] =sourceRDD.toDS();
    //personDS.printSchema()打印出錯信息
    
        val resultDS: Dataset[Person] =personDS.where('age>10)
          .select('name,'age)
          .as[Person]
        resultDS.show()
    
      }
      @Test
      def dfIntro(): Unit ={
        val spark: SparkSession =new SparkSession.Builder()
          .appName("ds intro")
          .master("local")
          .getOrCreate()
    
        import spark.implicits._
        val sourceRDD: RDD[Person] = spark.sparkContext.parallelize(Seq(Person("張三",10),Person("李四",15)))
        val df: DataFrame = sourceRDD.toDF()//隱shi轉換
    
        df.createOrReplaceTempView("person")//創建表
        val resultDF: DataFrame =spark.sql("select name from person where age>=10 and age<=20")
        resultDF.show()
    
      }
      @Test
      def database1(): Unit ={
        //1.創建sparkSession
        val spark: SparkSession =new SparkSession.Builder()
          .appName("database1")
          .master("local[6]")
          .getOrCreate()
          //2.導入引入shi子轉換
        import spark.implicits._
    
        //3.演示
        val sourceRDD: RDD[Person] =spark.sparkContext.parallelize(Seq(Person("張三",10),Person("李四",15)))
        val dataset: Dataset[Person] =sourceRDD.toDS()
    
        //Dataset 支持強類型的API
        dataset.filter(item => item.age >10).show()
        //Dataset 支持若弱類型的API
        dataset.filter('age>10).show()
        //Dataset 可以直接編寫SQL表達式
        dataset.filter("age>10").show()
      }
    
      @Test
      def database2(): Unit ={
        val spark: SparkSession = new SparkSession.Builder()
          .master("local[6]")
          .appName("database2")
          .getOrCreate()
        import spark.implicits._
    
        val dataset: Dataset[Person] =spark.createDataset(Seq(Person("張三",10),Person("李四",20)))
        //無論Dataset中放置的是什么類型的對象,最終執行計劃中的RDD上都是internalRow
        //直接獲取到已經分析和解析過得Dataset的執行計劃,從中拿到RDD
        val executionRdd: RDD[InternalRow] =dataset.queryExecution.toRdd
    
        //通過將Dataset底層的RDD通過Decoder轉成了和Dataset一樣的類型RDD
        val typedRdd:RDD[Person] = dataset.rdd
    
        println(executionRdd.toDebugString)
        println()
        println()
        println(typedRdd.toDebugString)
      }
    
      @Test
      def database3(): Unit = {
        //1.創建sparkSession
        val spark: SparkSession = new SparkSession.Builder()
          .appName("database1")
          .master("local[6]")
          .getOrCreate()
        //2.導入引入shi子轉換
        import spark.implicits._
    
        val dataFrame: DataFrame = Seq(Person("zhangsan", 15), Person("lisi", 20)).toDF()
        //3.看看DataFrame可以玩出什么花樣
        //select name from...
        dataFrame.where('age > 10)
          .select('name)
          .show()
      }
    //  @Test
    //  def database4(): Unit = {
    //    //1.創建sparkSession
    //    val spark: SparkSession = new SparkSession.Builder()
    //      .appName("database1")
    //      .master("local[6]")
    //      .getOrCreate()
    //    //2.導入引入shi子轉換
    //    import spark.implicits._
    //    val personList=Seq(Person("zhangsan",15),Person("lisi",20))
    //
    //    //1.toDF
    //    val df1: DataFrame =personList.toDF()
    //    val df2: DataFrame =spark.sparkContext.parallelize(personList).toDF()
    //      //2.createDataFrame
    //    val df3: DataFrame =spark.createDataFrame(personList)
    //
    //    //3.read
    //    val df4: DataFrame =spark.read.csv("")
    //    df4.show()
    //  }
      //toDF()是轉成DataFrame,toDs是轉成Dataset
      //  DataFrame就是Dataset[Row] 代表弱類型的操作,Dataset代表強類型的操作,中的類型永遠是row,DataFrame可以做到運行時類型安全,Dataset可以做到 編譯時和運行時都安全
    @Test
    def database4(): Unit = {
      //1.創建sparkSession
      val spark: SparkSession = new SparkSession.Builder()
        .appName("database1")
        .master("local[6]")
        .getOrCreate()
      //2.導入引入shi子轉換
      import spark.implicits._
      val personList=Seq(Person("zhangsan",15),Person("lisi",20))
      //DataFrame代表弱類型操作是編譯時不安全
      val df: DataFrame =personList.toDF()
    
      //Dataset是強類型的
      val ds: Dataset[Person] =personList.toDS()
      ds.map((person:Person) =>Person(person.name,person.age))
    }
      @Test
      def row(): Unit ={
        //1.Row如何創建,它是什么
        //row對象必須配合Schema對象才會有列名
        val p: Person =Person("zhangsan",15)
        val row: Row =Row("zhangsan",15)
        //2.如何從row中獲取數據
        row.getString(0)
        row.getInt(1)
        //3.Row也是樣例類、
        row match {
          case Row(name,age) => println(name,age)
        }
      }
    
    }
    case class Person(name: String, age: Int)

    SparkSQL如何運用

    以上就是“SparkSQL如何運用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    石家庄市| 武川县| 安康市| 平顶山市| 库伦旗| 岗巴县| 东光县| 宁陵县| 星子县| 莱州市| 五指山市| 厦门市| 拜泉县| 明星| 湾仔区| 志丹县| 白朗县| 金门县| 博客| 嫩江县| 册亨县| 朝阳县| 涞源县| 安阳县| 镇原县| 东明县| 马关县| 盐城市| 蓬莱市| 苍山县| 利津县| 邓州市| 惠安县| 邵武市| 辽宁省| 准格尔旗| 太原市| 华池县| 清水县| 永靖县| 诸城市|