Q: ネストしたモデルを使うにはどうすればいいですか?

A: ldbcでは、複数のカラムを組み合わせてネストしたモデルにマッピングすることができます。

例えば、UserモデルにNameというネストしたモデルを持たせ、データベース上では分割されたカラム(例: firstname、lastname)にマッピングする方法は以下の通りです。

// ネストしたモデルの定義
case class User(id: Long, name: User.Name, email: String)
object User:
  case class Name(firstName: String, lastName: String)

// テーブル定義の例
class UserTable extends Table[User]("user"):
  def id: Column[Long] = bigint().autoIncrement.primaryKey
  def firstName: Column[String] = varchar(255)
  def lastName: Column[String] = varchar(255)
  def email: Column[String] = varchar(255)
  
  // (firstName *: lastName)をUser.Nameに変換し、id、名前、emailをUserにマッピングする
  override def * : Column[User] =
    (id *: (firstName *: lastName).to[User.Name] *: email).to[User]
  
// 使用例:
TableQuery[UserTable].selectAll.query.to[List].foreach(println)
// UserTableのselectで取得されたレコードは、自動的にUser.Name(firstName, lastName)に変換される

この定義により、データベースのfirst_namelast_nameカラムがそれぞれUser.NameのfirstNameおよびlastNameに対応し、ネストしたモデルとして利用できます。

参考資料