pyspark之sparksql数据流转

在pyspark中,使用sparksql进行mysql数据的读写处理,将程序保存为test.py

一、准备工作
#-*- coding: UTF-8 -*- 
# 设置python的默认编码
import sys

# v3.x版本python,默认为utf-8
import importlib
importlib.reload(sys)

# 2.x版本python,使用reload,并定义默认编码格式
# reload(sys)
# sys.setdefaultencoding('utf-8')

# Spark 初始化
from pyspark.sql import SQLContext, SparkSession, Row
# spark在2.x后,直接使用spark.sql()执行sql脚本
spark = SparkSession.Builder().master('local').appName('sparkSql').config("spark.sql.warehouse.dir", "/user/hive/warehouse").enableHiveSupport().getOrCreate()
# spark在2.x后就弃用了这种方法:构建sql执行器
# sqlContext = SQLContext(spark) #sparksql方法
  • master()、appName() 、getOrCreate() 、enableHiveSupport()是SparkSession.Builder的方法
  • master():设置主名称。如果应用程序在本地运行,则是local;如果应用程序在集群上运行,则通常是 yarn 或 mesos,取决于集群配置
  • appName() :–应用程序的名称。它将显示在 Spark UI 中,可以自定义名称
  • enableHiveSupport():用于启用Hive支持,即在Spark中使用Hive元数据存储和查询数据
  • config(“spark.sql.warehouse.dir”, “Hive元数据存储的目录”):设置Hive元数据存储的目录。
    如config(“spark.sql.warehouse.dir”, “/user/hive/warehouse”)设置了Hive元数据存储的目录为/user/hive/warehouse
二、连接mysql数据库
# 设置数据库信息
prop = {
   'user':'','password':'','driver':'com.mysql.cj.jdbc.Driver'}
url_dim = 'jdbc:mysql://ip:port/kscs_dim?useUnicode=true&autoReconnect=true&characterEncoding=utf8&allowMultiQueries=true&serverTimezone=Asia/Shanghai'
url_ods = 'jdbc:mysql://am-bp14fo4aez0qi09y5167320o.ads.aliyuncs.com:3306/kscs_ods?useUnicode=true&autoReconnect=true&characterEncoding=utf8&allowMultiQueries=true&serverTimezone=Asia/Shanghai'
url_dwd = 'jdbc:mysql://ip:port/kscs_dwd?useUnicode=true&autoReconnect=true&characterEncoding=utf8&allowMultiQueries=true&serverTimezone=Asia/Shanghai'
url_dws = 'jdbc:mysql://ip:port/kscs_dws?useUnicode=true&autoReconnect=true&characterEncoding=utf8&allowMultiQueries=true&serverTimezone=Asia/Shanghai'
url_ads = 'jdbc:mysql://ip:port/kscs_ads?useUnicode=true&autoReconnect=true&characterEncoding=utf8&allowMultiQueries=true&serverTimezone=Asia/Shanghai'
三、读取mysql数据并写入mysql
1、表读取直接写入mysql

全量读取,直接写入mysql

# 读取数据
print('====read====')
data = spark.read.jdbc(url=url_ads, table='ads_ec_douyin_live_data', properties=prop)
print(type(data)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值