처음 (일주일 만에 두 번째) Play Framework에서 데이터베이스에 연결해보십시오.

13083 단어 PlayFrameworkScala

자, 이번 주 플레이는?



지난번 Play에서 API 돌아가기를 만들 수 있었으므로 이번에는 템플릿을 사용하여 html을 반환하고 & DB 연결을 시도합니다.

기다리지 마라. 이것은 준비다.



application.comf에 연결 정보를.
로컬로 움직이는 MySQL의 playdb라는 데이터베이스에 연결하는 경우입니다.

conf/application.conf
# (省略)

libraryDependencies += jdbc
play.db {
  config = "db"
  default = "default"
  prototype {
  }
}
db {
  default.driver=com.mysql.jdbc.Driver
  default.url="jdbc:mysql://localhost/playdb"
  default.username = user123
  default.password = "password123"
}

데이터는 이렇게 넣어 보았습니다.
+----+----------------------+--------------------------------------+---------------------------+
| id | company_name         | company_copy                         | addr                      |
+----+----------------------+--------------------------------------+---------------------------+
|  1 | 独立行政法人サンプル | 私たちはサンプルのためのサンプルです | 〒000-0123 銀河の果てまで |
|  2 | なんとか株式会社     | なんとかせんといかん会社             | 〒000-2222 東京都XXX      |
|  3 | テスト企業 01        | 企業1です!                          | 〒000-1111 東京都ほげほげ |
+----+----------------------+--------------------------------------+---------------------------+

build.sbt의 libraryDependencies에 mysql-connector-java를 추가합니다.

build.sbt
libraryDependencies ++= Seq(
  ...(省略)
  "mysql" % "mysql-connector-java" % "5.1.34"
)

괜찮아, 코딩이야.



MySQL의 DB에서 데이터를 가져와 표시하는 페이지를 만들어 보겠습니다.

우선 routes

conf/routes
GET     /companies         controllers.CompaniesController.index

CompaniesController는 이런 느낌

app/controllers/CompaniesController.scala
package controllers

import javax.inject._
import play.api._
import play.api.mvc._
import play.api.db._
import models.Company

@Singleton
class CompaniesController @Inject() (db1: Database) extends Controller {

  def index = Action {
    var str = ""
    var coms = List[Company]()
    val conn = db1.getConnection
    try {
      val stmt = conn.createStatement
      val rs = stmt.executeQuery("select * from companies order by id ASC limit 3")
      while (rs.next()) {
        coms = coms :+ new Company(rs)
      }
    } finally {
      conn.close
    }
    Ok(views.html.companies(coms))
  }

}

아무렇지도 않게 나온 Company는 이런 느낌.
stmt.executeQuery 는 ResultSet 형을 돌려주므로, ResultSet 를 인수로 하는 생성자도 만들어 보았습니다.
(이런 설계로 괜찮을까?)

models/Company.scala
package models

import java.sql.ResultSet

case class Company(_id: Int, _company_name: String, _company_copy: String, _addr: String) {
  var id = _id
  var company_name = _company_name
  var company_copy = _company_copy
  var addr = _addr

  def this() = {
    this(0, "", "", "")
  }
  def this(rs: ResultSet) = {
    this(rs.getInt("id"), rs.getString("company_name"), rs.getString("company_copy"), rs.getString("addr"))
  }

  def getId: Int = {
    return this.id
  }
  def getName: String = {
    return this.company_name
  }
  def getCopy: String = {
    return this.company_copy
  }
  def getAddr: String = {
    return this.addr
  }
}

view는 이런 식으로. 스타일이 짜증나는 것을 걱정하지 마십시오.

views/companies.scala.html
@(coms: List[Company])
<!DOCTYPE html>
<html lang="ja">
<head>
    <title>Companies</title>
    <link rel="shortcut icon" type="image/png" href="@routes.Assets.versioned("images/favicon.png")">
    <style>
    div.com{
      margin: 4px 12px;
      padding: 4px 8px;
      border: 2px solid rgb(127,191,191);
      border-radius: 2px;
    }
    p.name{
      border-left: 2px solid rgb(63,63,127);
      padding-left: 8px;
      font-size:110%;
    }
    p.addr{
      font-size: 90%;
    }
    </style>
</head>
<body>
  <header></header>
  <main>
    <h1>企業一覧</h1>
    @for(com <- coms){
        <div class="com">
        <p class="name">@com.getName</p>
        <p class="copy">@com.getCopy</p>
        <p class="addr">@com.getAddr</p>
        </div>
    }
  </main>
  <footer></footer>
</body>
</html>

이것으로 좋다.



좋은 웹페이지 즐겨찾기