Slick 2.0 Operaciones CRUD genéricas
He estado buscando cómo implementar un rasgo genérico para CRUD de bienes comunes y otros tipos de operaciones, miréesta yesta y el método especificado está funcionando bien.
Lo que me gustaría tener es un método genérico para la inserción, mi clase se ve así en este momento (implementación no genérica):
object CampaignModel {
val campaigns = TableQuery[Campaign]
def insert(campaign: CampaignRow)(implicit s: Session) = {
campaigns.insert(campaign)
}
}
Lo que intenté hasta ahora, siguiendo el primer enlace, fue esto (implementación genérica):
trait PostgresGeneric[T <: Table[A], A] {
val tableReference = TableQuery[T]
def insertGeneric(row: ? What type goes here ?)(implicit s: Session) = tableReference.insert(row)
}
Cuando inspecciono elinsert
método parece que el tipo correcto debería serT#TableElementType
pero mi conocimiento es bastante básico y no puedo entender los tipos, intentéT
yA
y el compilador dice que el classtype no se ajusta al rasgo de uno.
Otras informaciones, las tablas se generan con las herramientas de generación de tablas ingeniosas
case class CampaignRow(id: Long, name: Option[String])
/** Table description of table campaign. Objects of this class serve as prototypes for rows in queries. */
class Campaign(tag: Tag) extends Table[CampaignRow](tag, "campaign") {
def * = (id, name) <>(CampaignRow.tupled, CampaignRow.unapply)
/** Maps whole row to an option. Useful for outer joins. */
def ? = (id.?, name).shaped.<>({
r => import r._; _1.map(_ => CampaignRow.tupled((_1.get, _2)))
}, (_: Any) => throw new Exception("Inserting into ? projection not supported."))
/** Database column id AutoInc, PrimaryKey */
val id: Column[Long] = column[Long]("id", O.AutoInc, O.PrimaryKey)
/** Database column name */
val name: Column[Option[String]] = column[Option[String]]("name")
}