Ich verwende derzeit Slick 1.x für den Zugriff auf MySQL innerhalb von playframework 2.1.3. Während Slick im Allgemeinen ziemlich gut aussieht, kann ich mir nicht vorstellen, wie repetitiv die Deklarationssyntax ist. Ich meine, einen Blick auf den folgenden Code haben:Wie kann ich vermeiden, Slick-Modell Erklärung Ausführlichkeit und Wiederholbarkeit
case class User
(id: Option[Long]
, firstName: String
, lastName: String
, email: String
, password: String
, status: String
, createDate: Long = Platform.currentTime
, firstLogin: Option[Long]
, lastLogin: Option[Long]
, passwordChanged: Option[Long]
, failedAttempts: Int = 0
)
object User extends Table[User]("USER") {
def id = column[Long]("id", O.PrimaryKey, O.AutoInc)
def firstName = column[String]("firstName", O.NotNull)
def lastName = column[String]("lastName", O.NotNull)
def email = column[String]("mail", O.NotNull)
def password = column[String]("password", O.NotNull)
def status = column[String]("status", O.NotNull)
def createDate = column[Long]("createDate", O.NotNull)
def firstLogin = column[Long]("firstLogin", O.Nullable)
def lastLogin = column[Long]("lastLogin", O.Nullable)
def passwordChanged = column[Long]("passwordChanged", O.Nullable)
def failedAttempts = column[Int]("failedAttempts", O.NotNull)
def * = id.? ~ firstName ~ lastName ~ email ~ password ~ status ~ createDate ~ firstLogin.? ~ lastLogin.? ~ passwordChanged.? ~ failedAttempts <>(User.apply _, User.unapply _)
def autoInc = * returning id
}
Es kann nicht richtig sein, dass, um einen einfachen Fall der Klasse zu haben und eine Zugriffsobjekt, werde ich jedes einzelne Feld dreimal erklären müssen. Gibt es eine Möglichkeit, diese fehleranfällige Wiederholbarkeit zu vermeiden?
aktualisieren: Natürlich ist eine Lösung für dieses Problem sollte unterstützen lesen und Schreiboperationen.
Aus dem Thread: _ "Source-Code-Generation-basierte Typ-Provider werden wahrscheinlich mit kommenden Slick 2.1 später in diesem Jahr ausgeliefert." _ D. Dass sie nicht für die Produktion mit 1.x verwendbar sind. Code-Generatoren sind eine wirklich gute Möglichkeit, spröde Code zu erzeugen, aber fügen Sie nicht viel Beweglichkeit im Austausch. – keyboardsamurai
Was macht Code Gen in Ihren Augen nicht agil? – cvogt
Grundsätzlich löst es nur den ersten Schritt der Modellverwaltung. Du musst dich regenerieren und Veränderungen etc. verlieren. Es ist kein Muster, mit dem ich mich wohl fühle. Aber ich denke, bis 2.x Gold wird, muss dies tun. – keyboardsamurai