如何使查询在slick2中列出



我的表:

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]

我想得到包含"美国"one_answers"中国"的列表名称:

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

我想使用主题过滤器(….)……

您需要一个过滤器(在美国和中国进行过滤)和一个映射来转换为name、userId和descrebe,因此类似于(未经测试的)

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

结果是必须使用访问字段的元组列表_[索引]东西

[更新]我发现并不是所有的字段都在你的def中。。。所以这也是的一个特点

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

最新更新