欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

pyspark連接mysql數(shù)據(jù)庫報錯的解決

 更新時間:2023年11月07日 08:59:34   作者:猿界零零七  
本文主要介紹了pyspark連接mysql數(shù)據(jù)庫報錯的解決,因為spark中缺少連接MySQL的驅動程序,下面就來介紹一下解決方法,感興趣的可以了解一下

使用pyspark連接mysql數(shù)據(jù)庫代碼如下

spark_conf = SparkConf().setAppName("MyApp").setMaster("local")
 
spark = SparkSession.builder.config(conf=spark_conf).getOrCreate()
 
url = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false"
table_name = "tab_tf"
properties = {
    "user": "root",
    "password": "root"
}
 
# 讀取 MySQL 數(shù)據(jù)庫中的數(shù)據(jù)
df = spark.read.jdbc(url=url, table=table_name, properties=properties)
# 展示數(shù)據(jù)
df.show()

執(zhí)行時報錯了,錯誤信息如下:

py4j.protocol.Py4JJavaError: An error occurred while calling o32.jdbc.
: java.sql.SQLException: No suitable driver
    at java.sql.DriverManager.getDriver(DriverManager.java:315)
    at org.apache.spark.sql.execution.datasources.jdbc.JDBCOptions$$anonfun$6.apply(JDBCOptions.scala:105)
    at org.apache.spark.sql.execution.datasources.jdbc.JDBCOptions$$anonfun$6.apply(JDBCOptions.scala:105)
    at scala.Option.getOrElse(Option.scala:121)
    at org.apache.spark.sql.execution.datasources.jdbc.JDBCOptions.<init>(JDBCOptions.scala:104)
    at org.apache.spark.sql.execution.datasources.jdbc.JDBCOptions.<init>(JDBCOptions.scala:35)
    at org.apache.spark.sql.execution.datasources.jdbc.JdbcRelationProvider.createRelation(JdbcRelationProvider.scala:32)
    at org.apache.spark.sql.execution.datasources.DataSource.resolveRelation(DataSource.scala:332)
    at org.apache.spark.sql.DataFrameReader.loadV1Source(DataFrameReader.scala:242)
    at org.apache.spark.sql.DataFrameReader.load(DataFrameReader.scala:230)
    at org.apache.spark.sql.DataFrameReader.load(DataFrameReader.scala:186)
    at org.apache.spark.sql.DataFrameReader.jdbc(DataFrameReader.scala:257)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at py4j.reflection.MethodInvoker.invoke(MethodInvoker.java:244)
    at py4j.reflection.ReflectionEngine.invoke(ReflectionEngine.java:357)
    at py4j.Gateway.invoke(Gateway.java:282)
    at py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:132)
    at py4j.commands.CallCommand.execute(CallCommand.java:79)
    at py4j.GatewayConnection.run(GatewayConnection.java:238)
    at java.lang.Thread.run(Thread.java:748)

經(jīng)查詢,是因為spark中缺少連接MySQL的驅動程序,于是乎下載了與自己mysql數(shù)據(jù)庫版本一致的jar包,下載地址:https://downloads.mysql.com/archives/c-j/ 

查詢mysql版本命令:mysql -V

下載完成后,解壓,將mysql-connector-java-8.0.30.jar拷貝到spark安裝目錄的libs中

重新執(zhí)行程序,問題解決,執(zhí)行結果如下:

參考:py4j.protocol.Py4JJavaError: An error occurred while calling o32.jdbc.

到此這篇關于pyspark連接mysql數(shù)據(jù)庫報錯的解決的文章就介紹到這了,更多相關pyspark連接mysql內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • django批量導入xml數(shù)據(jù)

    django批量導入xml數(shù)據(jù)

    從網(wǎng)上下載的一些數(shù)據(jù),excel表格,xml文件,txt文件等有時候我們想把它導入數(shù)據(jù)庫,應該如何操作呢?下面我們就來詳細討論下。
    2016-10-10
  • python pandas loc 布爾索引示例說明

    python pandas loc 布爾索引示例說明

    loc跟iloc的區(qū)別,首先loc是location的意思,和iloc中i的意思是指integer,所以它只接受整數(shù)作為參數(shù),詳情見下面
    2022-03-03
  • Python調用IDM進行批量下載的實現(xiàn)

    Python調用IDM進行批量下載的實現(xiàn)

    本文主要介紹了Python調用IDM進行批量下載的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2025-04-04
  • python實現(xiàn)dbscan算法

    python實現(xiàn)dbscan算法

    DBSCAN 算法是一種基于密度的空間聚類算法,本文主要介紹了python實現(xiàn)dbscan算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Python 抓取數(shù)據(jù)存儲到Redis中的操作

    Python 抓取數(shù)據(jù)存儲到Redis中的操作

    這篇文章主要介紹了Python 抓取數(shù)據(jù)存儲到Redis中的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 用Python寫漏洞驗證腳本的代碼

    用Python寫漏洞驗證腳本的代碼

    這篇文章主要介紹了用Python寫漏洞驗證腳本,本文給大家分享完整實例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • Python環(huán)境變量設置方法

    Python環(huán)境變量設置方法

    默認情況下,在windows下安裝python之后,系統(tǒng)不會自動添加相應的環(huán)境變量。此時在命令行輸入python命令是不能執(zhí)行的,配置方法如下
    2016-08-08
  • 淺談Python 多進程默認不能共享全局變量的問題

    淺談Python 多進程默認不能共享全局變量的問題

    今天小編就為大家分享一篇淺談Python 多進程默認不能共享全局變量的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • PyTorch中的padding(邊緣填充)操作方式

    PyTorch中的padding(邊緣填充)操作方式

    今天小編就為大家分享一篇PyTorch中的padding(邊緣填充)操作方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python線程池模塊ThreadPoolExecutor用法分析

    Python線程池模塊ThreadPoolExecutor用法分析

    這篇文章主要介紹了Python線程池模塊ThreadPoolExecutor用法,結合實例形式分析了Python線程池模塊ThreadPoolExecutor的導入與基本使用方法,需要的朋友可以參考下
    2018-12-12

最新評論