日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SparkSQL 内置函数的使用(JAVA与Scala版本)

發布時間:2023/12/3 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SparkSQL 内置函数的使用(JAVA与Scala版本) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

SparkSQL 內置函數的使用(JAVA與Scala版本)

agg的使用(根據時間,去重id相同,統計相同時間內的id個數)

Scala版本!

package com.bynear.Scalaimport org.apache.spark.sql.functions._ import org.apache.spark.sql.types.{IntegerType, StringType, StructField, StructType} import org.apache.spark.sql.{Row, SQLContext} import org.apache.spark.{SparkConf, SparkContext} object SparkSQLAgg {def main(args: Array[String]) {val conf = new SparkConf().setMaster("local").setAppName("SparkSQLAgg")val sc = new SparkContext(conf)val sqlContext = new SQLContext(sc) //構建SQL上下文 //要使用Spark SQL的內置函授,就一定要導入SQLContext下的隱式轉換 import sqlContext.implicits._val userAccessLog = Array("2016-3-27,1122", "2016-3-27,1122", "2016-3-27,1123", "2016-3-27,1124", "2016-3-27,1124", "2016-3-28,1122" )val userAccessRDDLog = sc.parallelize(userAccessLog, 5)val userAccessLogRowRDD = userAccessRDDLog.map { log => Row(log.split(",")(0), log.split(",")(1).toInt) }val structType = StructType(Array(StructField("date", StringType, true), StructField("userid", IntegerType, true)))val userAccessLogRowDF = sqlContext.createDataFrame(userAccessLogRowRDD, structType); userAccessLogRowDF.groupBy("date").agg('date, countDistinct('userid)).map {row => Row(row(1), row(2))}.collect().foreach(println)} } Java版本!

package com.bynear.spark_sql; import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaRDD; import org.apache.spark.api.java.JavaSparkContext; import org.apache.spark.api.java.function.Function; import org.apache.spark.sql.DataFrame; import org.apache.spark.sql.Row; import org.apache.spark.sql.RowFactory; import org.apache.spark.sql.SQLContext; import org.apache.spark.sql.types.DataTypes; import org.apache.spark.sql.types.StructField; import org.apache.spark.sql.types.StructType; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import static org.apache.spark.sql.functions.*; //一定要引入: // //import static org.apache.spark.sql.functions.*; //否則無法直接使用countDistinct函數。本人在這里也是折騰了很久,最后查官網才發現這個坑的。 public class agg {public static void main(String[] args) {SparkConf conf = new SparkConf().setAppName("agg").setMaster("local"); JavaSparkContext sc = new JavaSparkContext(conf); SQLContext sqlContext = new SQLContext(sc); List<String> list = Arrays.asList("2016-3-27,1122", "2016-3-27,1122", "2016-3-27,1123", "2016-3-27,1124", "2016-3-27,1124", "2016-3-28,1122" ); JavaRDD<String> userAccessRDDLog = sc.parallelize(list, 5); JavaRDD<Row> mapROWRDD = userAccessRDDLog.map(new Function<String, Row>() {@Override public Row call(String line) throws Exception {String[] LineSplit = line.split(","); return RowFactory.create(LineSplit[0], Integer.valueOf(LineSplit[1])); }}); ArrayList<StructField> fields = new ArrayList<StructField>(); fields.add(DataTypes.createStructField("date", DataTypes.StringType, true)); fields.add(DataTypes.createStructField("userid", DataTypes.IntegerType, true)); StructType structType = DataTypes.createStructType(fields); DataFrame userAccessLogRowDF = sqlContext.createDataFrame(mapROWRDD, structType); userAccessLogRowDF.groupBy("date").agg(max("userid")).show(); sc.close(); } } 注意點:::

Scala版本中,如果需要使用內置函數,必須引用

import org.apache.spark.sql.functions._ Java版本,如果使用內置函數的話,必須引用

import static org.apache.spark.sql.functions.*; 必須為static 靜態的? 才可以使用其中的方法!




總結

以上是生活随笔為你收集整理的SparkSQL 内置函数的使用(JAVA与Scala版本)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。