Я хочу запросить одну строку от пользователя на основе Id. У меня следующий код манекенаВыберите одну строку на основе Id в Slick
case class User(
id: Option[Int],
name: String
}
object Users extends Table[User]("user") {
def id = column[Int]("id", O.PrimaryKey, O.AutoInc)
def name = column[String]("name")
def * = id ~ name <>(User, User.unapply _)
def findById(userId: Int)(implicit session: Session): Option[User] = {
val user = this.map { e => e }.where(u => u.id === userId).take(1)
val usrList = user.list
if (usrList.isEmpty) None
else Some(usrList(0))
}
}
Мне кажется, что findById
является излишним для запроса одного столбца, как Id является стандартным первичным ключом. Кто-нибудь знает какие-то лучшие способы? Обратите внимание, что я использую Play! 2.1.0
Как вы думаете, firstOption могут быть удалены из lifted.Query в Slick 2.1? Я считаю, что это было так. http://slick.typesafe.com/doc/2.1.0/api/#scala.slick.lifted.Query –
Прошло - этот ответ устарел сейчас – BrokenGlass