2016-04-08 9 views
0

Ich verwende playframework 2.5 mit Spiel glattPlayframework 2.5 Slick + DI

lazy val root = (project in file(".")).enablePlugins(PlayScala) 

scalaVersion := "2.11.7" 

libraryDependencies ++= Seq(
    cache, 
    ws, 
    "org.scalatestplus.play" %% "scalatestplus-play" % "1.5.0-RC1" % Test, 
    "com.madgag.spongycastle" % "core" % "1.53.0.0", 
    "org.flywaydb" %% "flyway-play" % "3.0.0", 
    "com.typesafe.play" %% "play-slick" % "2.0.0", 
    "com.typesafe.play" %% "play-slick-evolutions" % "2.0.0" 
) 

resolvers += "scalaz-bintray" at "http://dl.bintray.com/scalaz/releases" 


fork in run := false 

Und versuchen, grundlegende CRUD-Klasse mit DI zu implementieren, die durch Spiel offiziell empfohlen.

trait FooService { 
    def findById(id: Long) 

    final class FooTable(tag: Tag) extends Table[FooModel](tag,"foo"){ 
    def id = column[Long]("id") 
    //.... 
    } 
} 

@Singleton 
class FooServiceImpl @Inject()(protected val dbConfigProvider: DatabaseConfigProvider) extends FooService with HasDatabaseConfigProvider[JdbcProfile] { 
    import dbConfig.driver.api._ 

    private lazy val bars = TableQuery[FooTable] 

    def findById(id: Long) = db.run(bars.filter{ x => x.id === id}.result) 
    //.... 
} 

Module.scala

override def configure() = { 
    //.... 
    bind(classOf[FooService]).to(classOf[FooServiceImpl]) 
    //.... 
} 

application.conf

slick.dbs.default.driver = "slick.driver.MySQLDriver$" 
slick.dbs.default.db.driver = com.mysql.jdbc.Driver 
slick.dbs.default.db.url = "jdbc:mysql://localhost/foo" 
slick.dbs.default.db.user = "root" 
slick.dbs.default.db.password = "password" 

ich einen Fehler Caused by: java.lang.RuntimeException: driverClassName specified class 'com.mysql.jdbc.Driver' could not be loaded mit Codes erhalten/Einstellung über

der Fehler wird verschwinden, wenn ich slick.dbs.default.db.dataSourceClass = "slick.jdbc.DatabaseUrlDataSource" hinzufügen application.conf, bekomme ich stattdessen DB Timeout Ausnahme.

Da mein anderes play2.4-Projekt (nicht DI) mit einem Server mit derselben Konfigurationseinstellung verbinden konnte und ich auch eine Verbindung zum Server in der Konsole herstellen konnte, bin ich mir sicher, dass die Db-Konfiguration korrekt ist.

Ich weiß nicht, was das Problem verursacht. Wo mache ich falsch?

Vielen Dank im Voraus.

+0

Veröffentlichen Sie bitte auch Ihre Datei build.sbt. – marcospereira

+0

@marcospereira aktualisiert. – suish

Antwort

2

Sie müssen die MySQL-Treiber Abhängigkeit hinzuzufügen:

libraryDependencies += "mysql" % "mysql-connector-java" % "5.1.38" 

Natürlich überprüfen die, wenn diese Version (die neueste) ok ist oder wenn Sie ein anderes brauchen.

+0

Ofc, Es muss da sein. Danke, dass du eine dumme Frage beantwortet hast. – suish