4

我就是想不通。我现在使用的是:

abstract class DBEnumString extends Enumeration {
  implicit val enumMapper = MappedJdbcType.base[Value, String](
     _.toString(),
     s => this.withName(s)
  )
}

接着:

object SomeEnum extends DBEnumString {
  type T = Value
  val A1 = Value("A1")
  val A2 = Value("A2")
}

问题是,在插入/更新 PostgreSQL 的 JDBC 驱动程序期间,当列类型为“some_enum”时,参数类型为“字符变化”,这是合理的,因为我将 SomeEnum 转换为 String。

如何告诉 Slick 将 String 视为 DB 定义的“enum_type”?或者如何定义将映射到“enum_type”的其他 Scala 类型?

4

1 回答 1

6

当我试图让我的 postgreSQL 枚举与 slick 一起工作时,我也有类似的困惑。Slick-pg允许您将 Scala 枚举与数据库枚举一起使用,并且测试套件显示了如何使用.

下面是一个例子。

假设我们的数据库中有这个枚举类型。

CREATE TYPE Dog AS ENUM ('Poodle', 'Labrador');

我们希望能够将这些映射到 Scala 枚举,以便我们可以愉快地与 Slick 一起使用它们。我们可以使用 slick-pg 来做到这一点,它是 slick 的扩展。

首先,我们制作上述枚举的 Scala 版本。

object Dogs extends Enumeration {
  type Dog = Value
  val Poodle, Labrador = Value
}

为了从 slick-pg 获得额外的功能,我们扩展了普通的 PostgresDriver 并说我们想将我们的 Scala 枚举映射到 PostgreSQL 的枚举(记住将 application.conf 中的 slick 驱动程序更改为您创建的驱动程序)。

object MyPostgresDriver extends PostgresDriver with PgEnumSupport {
  override val api = new API with MyEnumImplicits {}

  trait MyEnumImplicits {
    implicit val dogTypeMapper = createEnumJdbcType("Dog", Dogs)
    implicit val dogListTypeMapper = createEnumListJdbcType("Dog", Dogs)

    implicit val dogColumnExtensionMethodsBuilder = createEnumColumnExtensionMethodsBuilder(Dogs)
    implicit val dogOptionColumnExtensionMethodsBuilder = createEnumOptionColumnExtensionMethodsBuilder(Dogs)
  }
}

现在,当您想创建一个新的模型案例类时,只需使用相应的 Scala 枚举即可。

case class User(favouriteDog: Dog) 

当你做整个 DAO 表的恶作剧时,你可以再次使用它。

class Users(tag: Tag) extends Table[User](tag, "User") {
  def favouriteDog = column[Dog]("favouriteDog")
  def * = (favouriteDog) <> (Dog.tupled, Dog.unapply _)
}

显然,无论您在何处使用它,都需要在范围内使用 Scala Dog 枚举。

由于 slick 中的错误,目前您无法动态链接到自定义 slick 驱动程序application.conf(它应该可以工作)。这意味着您要么需要使用 start 运行 play framework 而不需要动态重新编译,要么您可以创建一个独立的 sbt 项目,其中仅包含自定义的 slick 驱动程序并在本地依赖它。

于 2015-06-18T16:01:03.897 回答