почему операция === не работает с фильтром или где не применяется к моему TableQuery [slick2]

Я использую slick 2.0.2 и scala, моя модель данных:

  case class AdItem(id:Option[Long], res:String,status:String,userId:String, head:String,summary:String, url:String, position:String)
class Advertisement(tag:Tag) extends Table[AdItem](tag, "Advertisement"){
  def id=column[Long]("ID", O.PrimaryKey, O.AutoInc)
  def res=column[String]("Resource")
  def status=column[String]("Status")
  def userId=column[String]("User")
  def head=column[String]("head")
  def summary=column[String]("Summary")
  def url=column[String]("Ad_Link")
  def position=column[String]("Position")
  def * = (id.?, res, status, userId,  head, summary, url, position)<>(AdItem.tupled, AdItem.unapply)
  def userFK=foreignKey("Ad_USE_FK", userId, userdata)(_.id)
}

это мой запрос таблицы:

val addata=TableQuery[Advertisement]

когда я выполняю:

val idd="1232232"
addata.filter(_.id === idd.toLong)

Я получаю ошибку:

[error] G:\testprojects\slickplay\app\controllers\AdController.scala:30: value =
== is not a member of scala.slick.lifted.Column[Long]
[error]       addata.filter(_.id === idd.toLong)

Я следую инструкциям http://slick.typesafe.com/doc/2.0.2/queries.html#sorting-and-filtering

Я думаю, что "===" может применить столбец [Длинный]


person user504909    schedule 31.05.2014    source источник


Ответы (1)


Вы должны импортировать правильные неявные преобразования:

import scala.slick.driver.JdbcDriver.simple._

or

import scala.slick.driver.TheDriverOfMyChoice.simple._
person DCKing    schedule 31.05.2014