我是Scala的新手,我正在尝试开发一个使用自定义库的小项目。我在库中创建了一个mysql连接池。这是我的build.sbt图书馆
organization := "com.learn"
name := "liblearn-scala"
version := "0.1"
scalaVersion := "2.12.6"
libraryDependencies += "mysql" % "mysql-connector-java" % "6.0.6"
libraryDependencies += "org.apache.tomcat" % "tomcat-dbcp" % "8.5.0"我也用sbt publishLocal向当地的常春藤出版社发表了同样的文章。
现在,我有了一个项目,它将使用下面的build.sbt库
name := "SBT1"
version := "0.1"
scalaVersion := "2.12.6"
libraryDependencies += "com.learn" % "liblearn-scala_2.12" % "0.1"我能够编译这个新项目,但是当我运行它时
java.lang.ClassNotFoundException: org.apache.tomcat.dbcp.dbcp2.BasicDataSource但如果我加上
libraryDependencies += "mysql" % "mysql-connector-java" % "6.0.6"
libraryDependencies += "org.apache.tomcat" % "tomcat-dbcp" % "8.5.0"在项目的build.sbt中,它的工作没有任何问题。
,这是用scala做事情的实际方法吗?ie :我必须提到自定义库在项目?中的依赖关系。
这是我的库代码(我只有一个文件)
package com.learn.scala.db
import java.sql.Connection
import org.apache.tomcat.dbcp.dbcp2._
object MyMySQL {
private val dbUrl = s"jdbc:mysql://localhost:3306/school?autoReconnect=true"
private val connectionPool = new BasicDataSource()
connectionPool.setUsername("root")
connectionPool.setPassword("xyz")
connectionPool.setDriverClassName("com.mysql.cj.jdbc.Driver")
connectionPool.setUrl(dbUrl)
connectionPool.setInitialSize(3)
def getConnection: Connection = connectionPool.getConnection
}这是我的项目代码:
try {
val conn = MyMySQL.getConnection
val ps = conn.prepareStatement("select * from school")
val rs = ps.executeQuery()
while (rs.next()) {
print(rs.getString("name"))
print(rs.getString("rank"))
println("----------------------------------")
}
rs.close()
ps.close()
conn.close()
} catch {
case ex: Exception => {
println(ex.printStackTrace())
}
}https://stackoverflow.com/questions/51964826
复制相似问题