spark 集成 ClickHouse 和 MySQL (读和写操作)(笔记)-CSDN博客

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

目录

前言

一.spark读出

1. spark 读出 MySQL表数据

1.2 spark 读出 ClickHouse表数据

 二.spark写入

1. spark 写入 MySQL表数据

 2.spark 写入 ClickHouse表数据


前言

这篇文章主要记录的是用spark集成ClickHouse和MySQL

将数据read出和将数据write写入表的 (记录笔记)

创建sparkSession

因为这个不是重点所以先简单创建下实际是需要按照你的需求创建的

// 创建SparkSession
val spark = SparkSession.builder()
  .appName("Write to MySQL")
  .config("spark.sql.catalogImplementation", "hive")
  .getOrCreate()

一.spark读出

1. spark 读出 MySQL表数据

//读取数据    
 spark.read.format("jdbc")
      .option("url","jdbc:mysql://address-ip:3306/ds_db01??characterEncoding=UTF-8")  //url
      .option("driver","com.mysql.jdbc.Driver")     //驱动
      .option("user","root")                        //用户名
      .option("password","123456")                   //密码
      .option("dbtable","product_info")                //表
      .load().createOrReplaceTempView("v")
    spark.sql("select * from v")      //查询

1.2 spark 读出 ClickHouse表数据

    //    以jdbc为连接方式进行连接clickhouse
    val frame = sc.read.format("jdbc")
      .option("driver","ru.yandex.clickhouse.ClickHouseDriver" )//      配置driver
      .option("url", "jdbc:clickhouse:/address-ip:8123/shtd_result")//       配置url
      .option("dbtable", "cityavgcmpprovince")
      .option("user", "default")
      .option("password", "123456")
      .load()

 二.spark写入

1. spark 写入 MySQL表数据

// 将数据写入MySQL表
processedData.write
  .format("jdbc")
  .option("driver", "com.mysql.jdbc.Driver")
  .option("url", "jdbc:mysql://mysql-host:3306/database")
  .option("dbtable", "mysql_table")
  .option("user", "username")
  .option("password", "password")
  .mode(SaveMode.Append)
  .save()

 2.spark 写入 ClickHouse表数据

// 将数据写入ClickHouse表
processeData.write
  .format("jdbc")
  .option("driver", "ru.yandex.clickhouse.ClickHouseDriver")
  .option("url", "jdbc:clickhouse://clickhouse-host:8123/database")
  .option("dbtable", "clickhouse_table")
  .option("user", "username")
  .option("password", "password")
  .mode(SaveMode.Append)
  .save()
processedData代表你处理好的数据的DataFrame对象。
path/to/processedData.parquet代表你处理好的数据的存储路径可以是Parquet、CSV等格式。
mysql-host代表MySQL数据库的主机名或IP地址。
database代表MySQL数据库的名称。
mysql_table代表要写入的MySQL表的名称。
username代表连接MySQL所需的用户名。
password代表连接MySQL所需的密码

mode参数

1. SaveMode.Append将新数据追加到目标表的末尾。如果表不存在则创建一个新表并保存数据。

2. SaveMode.Overwrite完全覆盖目标表的数据。如果表不存在则创建一个新表并保存数据。

3. SaveMode.ErrorIfExists如果目标表已经存在则抛出一个错误。用于避免意外地覆盖已有数据。

4. SaveMode.Ignore如果目标表已经存在则忽略保存操作不做任何处理。

这些参数用于指定保存数据时的行为。根据具体的需求选择合适的保存模式可以确保数据正确地保存到目标表中同时避免意外覆盖或丢失数据。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: mysql

“spark 集成 ClickHouse 和 MySQL (读和写操作)(笔记)-CSDN博客” 的相关文章