postgresql - 为什么使用 Slick 和 PostgreSQL 时 Play 操作失败并显示 "no suitable driver found"?

标签 postgresql scala playframework slick

我正在使用 Play Framework 编写 Scala 网络应用程序2.1.1 使用本地 Postgres 数据库和 Slick 1.0.0,我在这里遇到了似乎矛盾的事情。

这是我遇到的错误:

[SQLException: No suitable driver found for postgres://user:password@localhost:5432/postgres]
56  
57  def instance = Action {
58    Database.forURL("postgres://user:password@localhost:5432/postgres", driver = "org.postgresql.Driver") withSession {
59      val q = Retailer.map(_.name)
60      Ok(views.html.instance(q.list, newRForm))
61    }
62  }
63

其中userpassword分别是Postgres数据库的usernamepassword

java error (No suitable driver found)我发现:

  1. 您需要使用 Class.forName("org.postgresql.Driver");
  2. 在某处加载驱动程序
  3. 您的程序的类路径中需要 PostgreSQL 驱动程序的 jar 文件。

Application.scala 中,我有以下代码块:

{
  println(ConfigFactory.load().getString("db.default.url"))
  println(Class.forName("org.postgresql.Driver"))
} 

重新运行 play compile 结果:

(Server started, use Ctrl+D to stop and go back to the console...)

[info] play - database [default] connected at jdbc:postgresql://localhost:5432/postgres
[info] play - Application started (Dev)
postgres://user:password@localhost:5432/postgres
class org.postgresql.Driver
[error] application -

! @6ei1nhkop - Internal server error, for (GET) [/instance] ->

play.api.Application$$anon$1: Execution exception[[SQLException: No suitable driver found for jdbc:postgresql://user:password@localhost:5432/postgres]]
        at play.api.Application$class.handleError(Application.scala:289) ~[play_2.10.jar:2.1.1]
        at play.api.DefaultApplication.handleError(Application.scala:383) [play_2.10.jar:2.1.1]
        at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$17$$anonfun$apply$24.apply(PlayDefaultUpstreamHandler.scala:326) [play_2.10.jar:2.1.1]
        at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$17$$anonfun$apply$24.apply(PlayDefaultUpstreamHandler.scala:324) [play_2.10.jar:2.1.1]
        at play.api.libs.concurrent.PlayPromise$$anonfun$extend1$1.apply(Promise.scala:113) [play_2.10.jar:2.1.1]
        at play.api.libs.concurrent.PlayPromise$$anonfun$extend1$1.apply(Promise.scala:113) [play_2.10.jar:2.1.1]
java.sql.SQLException: No suitable driver found for jdbc:postgresql://user:password@localhost:5432/postgres
        at java.sql.DriverManager.getConnection(Unknown Source) ~[na:1.7.0_21]
        at java.sql.DriverManager.getConnection(Unknown Source) ~[na:1.7.0_21]
        at scala.slick.session.Database$$anon$2.createConnection(Database.scala:105) ~[slick_2.10-1.0.0.jar:1.0.0]
        at scala.slick.session.BaseSession.conn$lzycompute(Session.scala:207) ~[slick_2.10-1.0.0.jar:1.0.0]
        at scala.slick.session.BaseSession.conn(Session.scala:207) ~[slick_2.10-1.0.0.jar:1.0.0]
        at scala.slick.session.BaseSession.close(Session.scala:221) ~[slick_2.10-1.0.0.jar:1.0.0]

然后我运行 play dependencies 并且 postgres .jar 被解析了!

Here are the resolved dependencies of your application:
+--------------------------------------------------------+--------------------------------------------------------+-----------------------------------+
| ←[32mpostgresql:postgresql:9.1-901-1.jdbc4←[0m         | ←[37mats:ats_2.10:1.0-SNAPSHOT←[0m                     | ←[37mAs postgresql-9.1-901-1.jdbc4.jar←[0m |
+--------------------------------------------------------+--------------------------------------------------------+-----------------------------------+

为什么找不到合适的驱动程序?

conf/application.conf

# Database configuration
db.default.driver=org.postgresql.Driver
db.default.url="jdbc:postgres://user:password@localhost:5432/postgres"
db.default.user=user    
db.default.password=password

项目/Build.scala

import sbt._
import Keys._
import play.Project._

object ApplicationBuild extends Build {

  val appName    = "ats"
  val appVersion = "1.0-SNAPSHOT"

  val appDependencies = Seq(
    // Add your project dependencies here, 
    jdbc,
    "com.typesafe.slick" %% "slick"      % "1.0.0",
    "postgresql"         %  "postgresql" % "9.1-901-1.jdbc4"
  )

  val main = play.Project(appName, appVersion, appDependencies).settings(
    // Add your own project settings here    
  )

我的 /lib 中还有 postgresql-9.2-1002.jdbc4.jarslick_2.10-1.0.1-RC1.jar code> 文件,而我执行 SELECT version(); 的本地 Postgres 版本是 9.2.4 尽管 postgres 驱动程序分辨率似乎正在解析为 9.1 .jar,当我注释掉应用程序依赖性以让 /lib 单独包含时,/lib 似乎不在 Play 的 CLASSPATH 上。

我知道 Postgres url 是正确的,并且我能够在我的应用程序首次启动时连接到我的数据库。

最佳答案

你把事情搞混了。

So then I looked at this question which says...

  1. You'll need to load the driver somewhere. Class.forName("org.postgresql.Driver");
  2. You'll need the postgresql driver .jar file in the classpath of your program.

这不适用于这种情况。您有一个框架可以为您处理这些事情。您提到的那个问题描述了如何使用“原始”jdbc 访问数据库。


这是您应该如何做的。

首先你可以简化配置部分。 5432 是 postresql 的默认端口,localhost 也是默认主机。用户名和密码应放在 url 之外。

# Database configuration
db.default.driver=org.postgresql.Driver
db.default.url=jdbc:postgres:postgres
db.default.user=user    
db.default.password=password

现在定义适当的 sbt 依赖项。只需从 /lib 文件夹中删除 jar 文件,并通过更改 Build.scala appDependencies 来更新您的依赖项以获取最新的 PostgreSQL 驱动程序 (9.2)。请注意,groupId 已从 postgresql 更改为 org.postgresql

val appDependencies = Seq(
  // Add your project dependencies here, 
  jdbc,
  "com.typesafe.slick" %% "slick" % "1.0.0",
  "org.postgresql" % "postgresql" % "9.3-1102-jdbc41"
)

最后,您应该更改您的 Controller 以从配置中解析数据源:

def instance = Action {
  Database.forDataSource(DB.getDataSource()) withSession {
    val q = Retailer.map(_.name)
    Ok(views.html.instance(q.list, newRForm))
  }
}

关于postgresql - 为什么使用 Slick 和 PostgreSQL 时 Play 操作失败并显示 "no suitable driver found"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17054620/

相关文章:

django - 以单独的输入形式显示 django DateTimeRangeField()

scala - 为什么在显示运算符之后无法加入?

python-3.x - 找不到使用 python 程序创建的 postgres 表

c++ - 在 VS 2012 项目中使用 libpq (PostgreSQL) 库

python - 如何在 Databricks 的 PySpark 中使用 Scala 创建的 DataFrame

java - 如何在play框架中使用多个实体管理器-使用spring data JPA?

scala - 检查 Future[Boolean] 的结果是 true 还是 false

java - 是否可以在模板调用页面中拆分 doLayout?

java - 有没有办法用 Hibernate/JPQL 查询 PostgreSQL hstore?

list - Scala 列表串联,:::vs++