2016-01-14 4 views
0

делают свои первые шаги, с гладким, у меня есть таблицыпятна схемы - выборка присоединилась таблицы

case class Employee(name: String,last: String,department: Option[Int] = None,id: Option[Int] = None) 
class Employees (tag: Tag) extends Table[Employee](tag, "EMPLOYEES") { 
    // Auto Increment the id primary key column 
    def id = column[Int]("ID", O.PrimaryKey, O.AutoInc) 
    def name = column[String]("NAME", O.NotNull) 
    def last = column[String]("LAST", O.NotNull) 
    def dept = foreignKey("EMP_FK",deptId,departments)(_.id) 
    def * = (name,last,deptId.?, id.?) <> (Employee.tupled, Employee.unapply) 
    val departments = TableQuery[Departments] 
} 
case class DepartmentManager(id:Int,name:String,manager:String) 
case class Department(id:Option[Int],name:String,managerId:Int) 
class Departments (tag: Tag) extends Table[Department](tag, "DEPARTMENTS") { 
    val employees = TableQuery[Employees] 
    def id = column[Int]("ID", O.PrimaryKey, O.AutoInc) 
    def name = column[String]("NAME", O.NotNull) 
    def managerId = column[Int]("MANAGER_ID", O.Nullable) 
    def manager = foreignKey("EMP_FK",managerId,employees)(_.id) 
    def * = (id.?,name,managerId) <> (Department.tupled, Department.unapply) 
} 

, но я получаю ошибку компиляции:

Выражения типа запроса [Ничего, ничего, Seq] не соответствует ожидаемого списка типа [DepartmentManager

Я пытался сделать что-то вроде этого (просто чтобы проверить, я знаю, что это плохо):

def all: List[DepartmentManager] = db.withSession { implicit session => 
    val employees = TableQuery[Employees] 
    val x = for { 
     (d, e) <- departments join employees 
    } yield (d.id, d.name, e.name + " " + e.last) 

    x.iterator.map(t=> DepartmentManager(t._1,t._2,t._3)).toList 
    } 

, но он не дал мне желаемых результатов - результат последнего (t._1, t._2, t._3) выглядит

(1, Foo, (СОТРУДНИКИ Путь @ 1076478352._2) .NAME (СОТРУДНИКИ Путь @ 1076478352._2) .LAST)

пожалуйста совет

ответ

0
case class Employee(name: String, last: String, department: Option[Int] = None, id: Option[Int] = None) 

class Employees (tag: Tag) extends Table[Employee](tag, "EMPLOYEES") { 
    // Auto Increment the id primary key column 
    val departments = TableQuery[Departments] 

    def id = column[Int]("ID", O.PrimaryKey, O.AutoInc) 
    def name = column[String]("NAME", O.NotNull) 
    def last = column[String]("LAST", O.NotNull) 
    def deptId = column[Int]("DEPARTMENT", O.NotNull) 

    def deptFK = foreignKey("EMP_DEP_FK", deptId, departments)(_.id) 

    def * = (name, last, deptId.?, id.?) <>(Employee.tupled, Employee.unapply) 
} 

case class DepartmentManager(id: Int, name: String, manager: String) 

case class Department(id: Option[Int], name: String, managerId: Int) 

class Departments (tag: Tag) extends Table[Department](tag, "DEPARTMENTS") { 
    val employees = TableQuery[Employees] 
    def id = column[Int]("ID", O.PrimaryKey, O.AutoInc) 
    def name = column[String]("NAME", O.NotNull) 
    def managerId = column[Int]("MANAGER_ID", O.Nullable) 

    def managerFK = foreignKey("DEP_MAN_FK", managerId, employees)(_.id) 

    def * = (id.?, name, managerId) <>(Department.tupled, Department.unapply) 
} 


def all(implicit s: Session): List[DepartmentManager] = { 
    val employees = TableQuery[Employees] 
    val x = for { 
     (d, e) <- departments join employees on (_.managerId === _.id) 
    } yield (d.id, d.name, e.name + " " + e.last) 

    x.list.map(t => DepartmentManager(t._1, t._2, t._3)) 
} 

Yo u нужен неявный объект Session для вызова метода list или iterator по запросу.

+0

Спасибо, я редактировать мой вопрос с сессией, но результат от имени менеджера выглядит следующим образом: \t (СОТРУДНИКИ Путь @ 1076478352._2) .NAME (СОТРУДНИКИ Путь @ 1076478352._2) .LAST – igx

 Смежные вопросы

  • Нет связанных вопросов^_^