Slick table Query: проблема с распознаванием значений

Может ли кто-нибудь сказать мне, почему в этом случае:

Query(Users) foreach {case (userId, userName) =>       
    println(userId + ", " + userName) }

Scala распознает userId, но в этом случае:

val l = List[(Int, String)]()

Query(Users) foreach {
   case (userId, userName) =>
     l::(foo(List[(userId, userName)])) 
}

это не так? (например, userId справа от «=>» распознается во втором случае, но не в первом)

Users — это гладко смонтированная база данных, которая выглядит так:

object Users extends Table[(Int, String)]("Users") {

  def userId          = column[Int]("UserId", O.PrimaryKey, O.AutoInc)
  def userName        = column[String]("UserName")

  def * = userId ~ userName
}

person Alex Spangher    schedule 12.07.2013    source источник


Ответы (1)


Я думаю, что вы имеете в виду:

l::(foo(List((userId, userName))))

Когда вы заключаете что-то в квадратные скобки, вы пытаетесь ввести список, и я предполагаю, что вы на самом деле хотели вместо этого добавить Tuple из userId и userName в список.

Вы также можете написать это так, если все, что вы хотите сделать, это поместить это в этот List и вам не нужен этот экстрактор Tuple:

Query(Users) foreach { tup =>     
  l::(foo(List(tup))) 
}
person cmbaxter    schedule 12.07.2013
comment
спасибо cmbaxter! Не могли бы вы также взглянуть на этот дополнительный вопрос? stackoverflow.com/questions/17662215/ - person Alex Spangher; 15.07.2013