通过IDEA编写SparkSQL代码_SQL风格&&_DSL风格

通过IDEA编写SparkSQL代码_SQL风格与_DSL风格
1、SQL风格

package cn.itcast.sql
import org.apache.spark.SparkContext
import org.apache.spark.sql.{DataFrame, Dataset, SparkSession}
object WordCount {
def main(args: Array[String]): Unit = {
//1.创建SparkSession
val spark: SparkSession = SparkSession.builder().master(“local[]").appName(“SparkSQL”).getOrCreate()
val sc: SparkContext = spark.sparkContext
sc.setLogLevel(“WARN”)
//2.读取文件
val fileDF: DataFrame = spark.read.text(“D:\data\words.txt”)
val fileDS: Dataset[String] = spark.read.textFile(“D:\data\words.txt”)
//fileDF.show()
//fileDS.show()
//3.对每一行按照空格进行切分并压平
//fileDF.flatMap(.split(" ")) //注意:错误,因为DF没有泛型,不知道_是String
import spark.implicits.

val wordDS: Dataset[String] = fileDS.flatMap(_.split(" "))//注意:正确,因为DS有泛型,知道_是String
//wordDS.show()
/

±----+
|value|
±----+
|hello|
| me|
|hello|
| you|

*/
//4.对上面的数据进行WordCount
wordDS.createOrReplaceTempView(“t_word”)
val sql =
“””
|select value ,count(value) as count
|from t_word
|group by value
|order by count desc
“”".stripMargin
spark.sql(sql).show()
sc.stop()
spark.stop()
}
}

2、DSL风格

package cn.itcast.sql
import org.apache.spark.SparkContext
import org.apache.spark.sql.{DataFrame, Dataset, SparkSession}
object WordCount2 {
def main(args: Array[String]): Unit = {
//1.创建SparkSession
val spark: SparkSession = SparkSession.builder().master("local[]").appName(“SparkSQL”).getOrCreate()
val sc: SparkContext = spark.sparkContext
sc.setLogLevel(“WARN”)
//2.读取文件
val fileDF: DataFrame = spark.read.text(“D:\data\words.txt”)
val fileDS: Dataset[String] = spark.read.textFile(“D:\data\words.txt”)
//fileDF.show()
//fileDS.show()
//3.对每一行按照空格进行切分并压平
//fileDF.flatMap(.split(" ")) //注意:错误,因为DF没有泛型,不知道_是String
import spark.implicits.

val wordDS: Dataset[String] = fileDS.flatMap(_.split(" "))//注意:正确,因为DS有泛型,知道_是String
//wordDS.show()
/

±----+
|value|
±----+
|hello|
| me|
|hello|
| you|

*/
//4.对上面的数据进行WordCount
wordDS.groupBy(“value”).count().orderBy($“count”.desc).show()
sc.stop()
spark.stop()
}
}

发布了238 篇原创文章 · 获赞 429 · 访问量 25万+

猜你喜欢

转载自blog.csdn.net/qq_45765882/article/details/105561251