从单个jar运行时,没有为jdbc:mysql找到合适的驱动程序

时间:2011-07-11 03:44:51

标签: mysql scala sbt

我有一个Scala测试项目,它将一些信息写入mysql数据库。我用sbt设置了项目,并使用sbt-eclipsify,所以我可以从eclipse运行它。我还使用sbt插件sbt-assembly创建了一个包含我需要的依赖jar的所有类的jar。我可以运行程序,没有问题来自eclipse和sbt。

我从sbt-assembly构建的单个jar中运行它:

java -classpath target/test1-assembly-1.0-SNAPSHOT.jar example.InsertDataIntoDatabase

但它失败了:

  

找不到适合jdbc的驱动程序:mysql:// localhost:3306 / test

我的第一个想法是sbt-assembly可能已经错过了mysql驱动程序依赖项,但我解压缩了jar,并在其中找到了com / mysql / jdbc / Driver.class。

是否还有一些其他依赖可能会丢失?

如何解决这个问题?

2 个答案:

答案 0 :(得分:2)

使用sbt-assembly插件“uberjar”我的应用时遇到此问题。在我的情况下,问题是在组装过程中丢失META-INF/services/java.sql.Driver文件。所以我需要更改程序集配置以使文件保持原位:

assemblyMergeStrategy in assembly := {
  case PathList("META-INF", xs@_*) =>
    xs.map(_.toLowerCase) match {
      case ("manifest.mf" :: Nil) |
           ("index.list" :: Nil) |
           ("dependencies" :: Nil) |
           ("license" :: Nil) |
           ("notice" :: Nil) => MergeStrategy.discard
      case _ => MergeStrategy.first // was 'discard' previousely
    }
  case "reference.conf" => MergeStrategy.concat
  case _ => MergeStrategy.first
}

答案 1 :(得分:0)

你能举一个初始化代码的例子吗?

JDBC驱动程序通常需要加载驱动程序的类来调用静态初始化代码并在DriverManager中注册它。对于MySQL,这可以通过以下方式完成:

Class.forName("com.mysql.jdbc.Driver")