我有一个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。
是否还有一些其他依赖可能会丢失?
如何解决这个问题?
答案 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")