zoukankan      html  css  js  c++  java
  • 编程实现利用 DataFrame 读写 MySQL 的数据

    package scala
    
    import java.util.Properties
    import org.apache.spark.sql.types._
    import org.apache.spark.sql.Row
    import org.apache.spark.SparkConf
    import org.apache.spark.SparkContext
    import org.apache.spark.sql.SQLContext
    object TestMySQL {
     def main(args: Array[String]) {
        val conf = new SparkConf()
            conf.setMaster("local")  
                .setAppName("scalawordcount")    //设置运行方式为本地     
        val sc = new SparkContext(conf)  
        var sqlContext = new SQLContext(sc) 
        val employeeRDD = sqlContext.sparkContext.parallelize(Array("3 Mary F 26","4 Tom M 23")).map(_.split(" "))
        val schema = StructType(List(StructField("id", IntegerType, true),StructField("name", StringType, true),StructField("gender", StringType, true),StructField("age", IntegerType, true)))
        val rowRDD = employeeRDD.map(p => Row(p(0).toInt,p(1).trim, p(2).trim,p(3).toInt))
        val employeeDF = sqlContext.createDataFrame(rowRDD, schema)
        val prop = new Properties()
    prop.put("user", "root") 
    prop.put("password", "root") 
    prop.put("driver","com.mysql.jdbc.Driver")
    prop.put("url","jdbc:mysql://localhost:3306/sparktest")
    employeeDF.write.mode("append").jdbc("jdbc:mysql://localhost:3306/sparktest", "sparktest.employee", prop)
    val jdbcDF = sqlContext.read.format("jdbc").option("url", "jdbc:mysql://localhost:3306/sparktest").option("driver","com.mysql.jdbc.Driver").option("dbtable","employee").option("user","root").option("password", "root").load()
    jdbcDF.agg("age" -> "max", "age" -> "sum")
    jdbcDF.show()
    
     }
    }

    此代码为scala语言所写,经调试可用。

  • 相关阅读:
    Android 添加cookie
    解决安卓TextView异常换行,参差不齐等问题
    Java遍历List的时候删除item
    android setCompoundDrawables 不显示问题
    Git 操作的一些场景
    C# 函数参数中的this
    Git 常用命令
    C# 判断程序是否执行 进行启动或前台显示
    在窗体中嵌入 应用程序
    byte[] 转 2进制字符串
  • 原文地址:https://www.cnblogs.com/zhangliqiangvictory/p/10627233.html
Copyright © 2011-2022 走看看