删除MySQL表与SparkSQL [英] Dropping MySQL table with SparkSQL

查看:4036
本文介绍了删除MySQL表与SparkSQL的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我知道,我们可以查询,或通过下面的命令创建一个SparkSQL MySQL表。

I know that we can query or create a Mysql table from SparkSQL through the below commands.

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)

就像是有什么办法删除表?

Like that is there any way to drop a table ?

推荐答案

您可以尝试用JDBC驱动程序基本的拖放操作:

You can try a basic DROP operation with the JDBC driver :

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 但这是更为直接。

You can do that with Spark using JDBCUtils but this is more straightforward.

这篇关于删除MySQL表与SparkSQL的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆