2016-09-25 51 views
0

我是一个新的Slick用户,我对表的“*”方法有问题。我不明白。下面的代码: 包款无法获得光滑表的“*”方法

import slick.lifted.{ProvenShape, ForeignKeyQuery} 
import slick.driver.PostgresDriver.api._ 

import scala.concurrent.ExecutionContext.Implicits.global 

case class Coordonnee (id:Option[Long], 
         email:String,email_publique:Boolean,email_publique_assoc:Boolean, 
         rue:String,rue_publique:Boolean,rue_publique_assoc:Boolean, 
         codepostal:String,codepostal_publique:Boolean,codepostal_publique_assoc:Boolean, 
         ville:String,ville_publique:Boolean,ville_publique_assoc:Boolean, 
         phone:String,phone_publique:Boolean,phone_publique_assoc:Boolean, 
         phonemaison:String,phonemaison_publique:Boolean,phonemaison_publique_assoc:Boolean 
        ) 
class Coordonnees(tag:Tag) extends extends Table[Coordonnee](tag, "COORDONNEES"){ 

    def id = column[Long]("COORDONNEES_ID", O.AutoInc, O.PrimaryKey) 

    def email = column[String]("EMAIL") 
    def email_publique = column[Boolean]("EMAIL_PUBLIQUE") 
    def email_publique_assoc = column[Boolean]("EMAIL_PUBLIQUE_ASSOC") 

    def rue = column[String]("RUE") 
    def rue_publique = column[Boolean]("RUE_PUBLIQUE") 
    def rue_publique_assoc = column[Boolean]("RUE_PUBLIQUE_ASSOC") 

    def codepostal = column[String]("CODEPOSTAL") 
    def codepostal_publique = column[Boolean]("CODEPOSTAL_PUBLIQUE") 
    def codepostal_publique_assoc = column[Boolean]("CODEPOSTAL_PUBLIQUE_ASSOC") 

    def ville = column[String]("VILLE") 
    def ville_publique = column[Boolean]("VILLE_PUBLIQUE") 
    def ville_publique_assoc = column[Boolean]("VILLE_PUBLIQUE_ASSOC") 

    def phone = column[String]("PHONE") 
    def phone_publique = column[Boolean]("PHONE_PUBLIQUE") 
    def phone_publique_assoc = column[Boolean]("PHONE_PUBLIQUE_ASSOC") 

    def phonemaison = column[String]("PHONEMAISON") 
    def phonemaison_publique = column[Boolean]("PHONEMAISON_PUBLIQUE") 
    def phonemaison_publique_assoc = column[Boolean]("PHONEMAISON_PUBLIQUE_ASSOC") 

    def * : ProvenShape[(Long, 
    String,Boolean,Boolean, 
    String, Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean)]= 
    (id, 
    email, email_publique, email_publique_assoc, 
    rue,rue_publique,rue_publique_assoc, 
    codepostal,codepostal_publique, codepostal_publique_assoc, 
    ville,ville_publique,ville_publique_assoc, 
    phone,phone_publique,phone_publique_assoc, 
    phonemaison,phonemaison_publique,phonemaison_publique_assoc 
    ) <> (Coordonnee.tupled, Coordonnee.unapply) 
} 

的理念IDE中的错误是:

Error:Play 2 Compiler: Required level: slick.lifted.FlatShapeLevel Source type: (slick.lifted.Rep[Long], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean], slick.lifted.Rep[String], slick.lifted.Rep[Boolean], slick.lifted.Rep[Boolean]) Unpacked type: (Option[Long], String, Boolean, Boolean, String, Boolean, Boolean, String, Boolean, Boolean, String, Boolean, Boolean, String, Boolean, Boolean, String, Boolean, Boolean)

我使用油滑V3.1.1。如果我删除

<> (Coordonnee.tupled, Coordonnee.unapply)

它的工作原理,但我需要它。

第一编辑:修改 “延伸表[......” 由pamu

回答

1

代替Table[(....)]使用Table[Coordonnee]

取而代之的是代码

class Coordonnees(tag:Tag) extends Table[(Long, 
    String,Boolean,Boolean, 
    String, Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean, 
    String,Boolean,Boolean 

)](tag, "COORDONNEES") { //.... } 

使用此代码

的建议
class Coordonnees(tag:Tag) extends Table[Coordonnee] { //... } 

编译完成的代码在*方法id

import slick.lifted.{ProvenShape, ForeignKeyQuery} 
import slick.driver.PostgresDriver.api._ 

import scala.concurrent.ExecutionContext.Implicits.global 

case class Coordonnee(id: Option[Long], 
         email: String, email_publique: Boolean, email_publique_assoc: Boolean, 
         rue: String, rue_publique: Boolean, rue_publique_assoc: Boolean, 
         codepostal: String, codepostal_publique: Boolean, codepostal_publique_assoc: Boolean, 
         ville: String, ville_publique: Boolean, ville_publique_assoc: Boolean, 
         phone: String, phone_publique: Boolean, phone_publique_assoc: Boolean, 
         phonemaison: String, phonemaison_publique: Boolean, phonemaison_publique_assoc: Boolean 
        ) 

class Coordonnees(tag: Tag) extends Table[Coordonnee](tag, "COORDONNEES") { 

    def id = column[Long]("COORDONNEES_ID", O.AutoInc, O.PrimaryKey) 

    def email = column[String]("EMAIL") 

    def email_publique = column[Boolean]("EMAIL_PUBLIQUE") 

    def email_publique_assoc = column[Boolean]("EMAIL_PUBLIQUE_ASSOC") 

    def rue = column[String]("RUE") 

    def rue_publique = column[Boolean]("RUE_PUBLIQUE") 

    def rue_publique_assoc = column[Boolean]("RUE_PUBLIQUE_ASSOC") 

    def codepostal = column[String]("CODEPOSTAL") 

    def codepostal_publique = column[Boolean]("CODEPOSTAL_PUBLIQUE") 

    def codepostal_publique_assoc = column[Boolean]("CODEPOSTAL_PUBLIQUE_ASSOC") 

    def ville = column[String]("VILLE") 

    def ville_publique = column[Boolean]("VILLE_PUBLIQUE") 

    def ville_publique_assoc = column[Boolean]("VILLE_PUBLIQUE_ASSOC") 

    def phone = column[String]("PHONE") 

    def phone_publique = column[Boolean]("PHONE_PUBLIQUE") 

    def phone_publique_assoc = column[Boolean]("PHONE_PUBLIQUE_ASSOC") 

    def phonemaison = column[String]("PHONEMAISON") 

    def phonemaison_publique = column[Boolean]("PHONEMAISON_PUBLIQUE") 

    def phonemaison_publique_assoc = column[Boolean]("PHONEMAISON_PUBLIQUE_ASSOC") 

    def * 
    = (id.?, 
    email, email_publique, email_publique_assoc, 
    rue, rue_publique, rue_publique_assoc, 
    codepostal, codepostal_publique, codepostal_publique_assoc, 
    ville, ville_publique, ville_publique_assoc, 
    phone, phone_publique, phone_publique_assoc, 
    phonemaison, phonemaison_publique, phonemaison_publique_assoc 
    ) <> (Coordonnee.tupled, Coordonnee.unapply) 
} 

通知替换为id.?

+0

谢谢你的提示。但是这并不能解决我的问题。 – f7h

+0

@ f7h ...编辑答案..请立即检查 – pamu

+0

看看'sbt compile'是否先运行。 Intellij不是最终的答案。 – Reactormonk