0

我的桌子:

case class Subject(id: Int, name:String, describe: String, sub_resource:String, addId:Long, recommand:Int, commentsum :Int, commentnumber: Int, userId: Int)
class Subjects(tag: Tag) extends Table[Subject](tag, "Subject") {
  def id=column[Int]("ID", O.PrimaryKey)
  def name=column[String]("Name")
  def describe=column[String]("describe")
  def sub_resource=column[String]("Resource")
  def keywords=column[String]("Keyword")
  def addID=column[Long]("Address")
  def recommandrate=column[Int]("Recommand")
  def commentsum=column[Int]("Sum_of_rate")
  def commentnumber=column[Int]("Rate_number")
  def userId=column[Int]("owner")
  def uniqueName = index("idx_grp_name", name, unique = true)
  def * = (id, name,sub_resource,keywords, addID, recommandrate, commentsum, commentnumber,userId)<> (Subject.tupled, Subject.unapply)
  def sub_res=foreignKey("sub_res_FK", sub_resource, resource)(_.link)
  def sub_address=foreignKey("sub_add_FK", addID, address)(_.id)
  def sub_user=foreignKey("sub_user_FK", userId, user)(_.id)
}
val subject = TableQuery[Subjects]

我想让列表名称包含“USA”和“China”:

如何编写过滤器并列出名称、userId 和描述?

我想使用 subject.filter(....).....

4

1 回答 1

0

您需要一个过滤器(用于过滤美国和中国)和一个地图来转换为名称、用户 ID 和描述,例如(未经测试)

subject.filter(i => i.name === "USA" || i.name === "China")
       .map(i => (i._2, i._10, i._3) 

结果是一个元组列表,您必须使用 ._[index] thingie 访问字段

[更新] 我发现并非您的所有字段都在您的 def * = ... 所以这也是值得关注的

由 cvogt 编辑:我更正了语法。这就像使用 Scala 集合一样,除了 ===。

于 2014-04-10T07:16:50.630 回答