如何使用Play框架在Slick2中添加外键约束

时间:2015-01-11 17:49:47

标签: scala playframework-2.0 slick-2.0

我想在我的一个Play2 Framework模型中使用Slick 2添加外键约束。 参考文件Slick2-Mapping-Configuration

假设我在两个scala文件中定义了两个模型:Person目录中的Addressmodels

使用文档中的代码引用无济于事,因为这两个类都位于单独的文件中。 我如何在PersonAddress上声明外键?任何代码参考都会更有帮助。

由于

1 个答案:

答案 0 :(得分:0)

假设您的两个类都位于同一个包中,则此代码应该起作用:

<Person.scala>
package the.package.name

type Person = (Int,String,Int,Int)
class People(tag: Tag) extends Table[Person](tag, "PERSON") {
  def id = column[Int]("ID", O.PrimaryKey, O.AutoInc)
  def name = column[String]("NAME")
  def age = column[Int]("AGE")
  def addressId = column[Int]("ADDRESS_ID")
  def * = (id,name,age,addressId)
  def address = foreignKey("ADDRESS",addressId,addresses)(_.id)
}

object people extends TableQuery(new People(_)) {
  val findByName = this.findBy(_.name)
  // more methods there
}


<Address.scala>
package the.package.name

type Address = (Int,String,String)
class Addresses(tag: Tag) extends Table[Address](tag, "ADDRESS") {
  def id = column[Int]("ID", O.PrimaryKey, O.AutoInc)
  def street = column[String]("STREET")
  def city = column[String]("CITY")
  def * = (id,street,city)
}

object addresses extends TableQuery(new Addresses(_)) {
  val findByName = this.findBy(_.name)
  // more methods there
}