在迁移到Play 2.5时,我采用了依赖注入设计模式,包括用于(JDBC)数据库访问。使用case class/companion对象模式时的Scala依赖注入
在一流水平,我理解这个概念:
class Users @Inject() (db: Database)
但我还没有看到如何,当你需要的情况下阶层和同伴对象模式的方法内的数据库访问,这可能应用的讨论。一个例子基本模型之中:
package models
import anorm._
import anorm.SqlParser._
import javax.inject._
import play.api.db._
import play.api.libs.functional.syntax._
import play.api.libs.json._
case class User @Inject() (db: Database) (
id: Option[Long] = None,
email: String
) {
def save = {
id.map { id => User.findById(id) } match {
case None => create
case _ => update
}
}
def create = db.withConnection { implicit conn =>
SQL(
"""INSERT INTO users (email) VALUES ({email})"""
).on(
'email -> email
).executeUpdate()
this
}
def update = ...
}
object User {
val simple = {
get[Option[Long]]("id") ~
get[String]("email") map {
case id ~ email =>
User(id, email)
}
}
def findById(id: Long) = db.withConnection { implicit conn =>
SQL("""SELECT * FROM users WHERE id = {id}""").on('id -> id).as(User.simple.singleOpt)
}
}
这改变的情况下类的签名(使其无法使用内val simple = { ... }
),我无法弄清楚如何注入/在同伴对象访问数据库。在对象内尝试@Inject() var db: Database _
会导致我想避免的NullPointerException的世界。
在一个依赖注入的世界中,这种常见用例的推荐设计模式是什么?
案例类并不意味着封装这样的“服务”功能,而DI也不是用于与对象一起工作 – cchantep