簡體   English   中英

使用SparkSQL刪除MySQL表

[英]Dropping MySQL table with SparkSQL

我知道我們可以通過以下命令從SparkSQL查詢或創建Mysql表。

val data = sqlContext.read.jdbc(urlstring, tablename, properties)
data.write.format("com.databricks.spark.csv").save(result_location)

val dataframe = sqlContext.read.json("users.json")
dataframe.write.jdbc(urlstring, table, properties)

像那樣有什么方法可以放桌子嗎?

您可以嘗試使用JDBC驅動程序進行基本的DROP操作:

val DB_URL: String = ???
val USER: String = ???
val PASS: String = ???

def dropTable(tableName: String) = {

    import java.sql._;

    var conn: Connection = null;
    var stmt: Statement = null;

    try {
      Class.forName("com.mysql.jdbc.Driver");
      println("Connecting to a selected database...");
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      println("Connected database successfully...");
      println("Deleting table in given database...");
      stmt = conn.createStatement();
      val sql: String = s"DROP TABLE ${tableName} ";
      stmt.executeUpdate(sql);
      println(s"Table ${tableName} deleted in given database...");
    } catch {
      case e: Exception => println("exception caught: " + e);
    } finally {
      ???
    }
}

dropTable("test")

您可以使用JDBCUtils在Spark上JDBCUtils此操作,但這非常簡單。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM