使用Play 2 Framework在Scala中创建模型类

时间:2013-09-27 08:26:03

标签: scala playframework playframework-2.0

我有一个包含用户模型的Play项目。之前,我使用case class声明和object声明来访问我的应用程序中的模型。有用。

但是现在我要声明一个User类,以拥有多个实例;因为我已经明白,当你有一个带有对象的模型时,它就是一个单例,所以只有一个实例。

我的项目是一个拥有众多用户的网站。

当我宣布我的课时,例如:

class User(val username: String,  var firstname: String, var lastname: String, var company: String, var password: String){}

我的应用程序(Application.scala)

未识别该模型

我怎样才能意识到自己想要的东西?

旧代码:

case class User(username: String, password: String, firstname: String, lastname: String, company: String)

object User {

val simple = {
  get[String]("username")  ~
  get[String]("password") ~
  get[String]("firstname") ~
  get[String]("lastname")  ~
  get[String]("company") map {
    case username~password~firstname~lastname~company =>
      User(username, password, firstname, lastname, company)
  }
}

def findAll(): Seq[User] = {
  DB.withConnection { implicit connection =>
    SQL("SELECT * FROM user").as(User.simple *)
  }
}

def create(user: User): Unit = {
  DB.withConnection { implicit connection =>
    SQL("INSERT INTO user(username, password, firstname, lastname, company) VALUES   ({username}, {password}, {firstname}, {lastname}, {company})").on(
      'username  -> user.username,
      'password  -> user.password,
      'firstname -> user.firstname,
      'lastname  -> user.lastname,
      'company   -> user.company
    ).executeUpdate()
  }
}

def getOne(username: String): Option[User] = {
  DB.withConnection { implicit connection =>
    val selectUser = SQL("SELECT username, password, firstname, lastname, company FROM user where username={username}")
                      .on('username -> "azuken")()
                      .collectFirst {
                        case Row(username: String, password: String, firstname: String, lastname: String, company: String) =>
                          User(username, password, firstname, lastname, company)
                        case Row(username:String, password:String, firstname: String) =>
                          User(username, password, "bobby", "lqsdast", "sdf")
                        case _ =>
                          User("username", "password", "firstname", "lastname", "company")
                      }
    selectUser
  }
} 

def authentication(username: String, password: String): Long = {
  DB.withConnection { implicit connection =>
    val firstRow = SQL("SELECT COUNT(*) AS NbRep FROM user WHERE username = {username} AND password = {password}").on(
      'username -> username,
      'password -> password
    ).apply().head
    firstRow[Long]("NbRep")
  }
} 

}

0 个答案:

没有答案