我想在我的一个Play2 Framework模型中使用Slick 2添加外键约束。 参考文件Slick2-Mapping-Configuration
假设我在两个scala文件中定义了两个模型:Person
目录中的Address
和models
。
使用文档中的代码引用无济于事,因为这两个类都位于单独的文件中。
我如何在Person
到Address
上声明外键?任何代码参考都会更有帮助。
由于
答案 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
}