在Slick 3.0.0中与Play Framework一起使用连接池的最佳实践

时间:2015-03-24 07:29:54

标签: scala playframework-2.0 slick hikaricp

我使用Typesafe Config作为数据库连接配置,遵循Slick 3.0.0-RC1的documentation。这是我的conf:

database = {
  driver = "org.postgresql.Driver"
  url = "jdbc:postgresql://localhost:5432/postgre"
  user = "postgre"
}

我建立了一个文件Locale.scala

package models

import slick.driver.PostgresDriver.api._
import scala.concurrent.Future

case class Locale(id: String, name: String)

class Locales(tag: Tag) extends Table[Locale](tag, "LOCALES") {
  def id = column[String]("ID", O.PrimaryKey)
  def name = column[String]("NAME")

  def * = (id, name) <> (Locale.tupled, Locale.unapply)
}

object Locales {
  private val locales = TableQuery[Locales]

  val db = Database.forConfig("database")

  def count: Future[Int] =
    try db.run(locales.length.result)
    finally db.close
}

然后我感到困惑的是,在适当的时间使用

创建Database对象的时间和地点
val db = Database.forConfig("database")

如果我像这样创建db,那么将有与我的模型一样多的数据库对象。那么这项工作的最佳做​​法是什么?

1 个答案:

答案 0 :(得分:0)

您可以创建一个Object DBLocator并使用惰性运算符加载它,以便仅在需要时加载它。

您始终可以调用DBLocator类中定义的方法来获取Session的实例。