처음 (일주일 만에 두 번째) 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>
이것으로 좋다.
Reference
이 문제에 관하여(처음 (일주일 만에 두 번째) Play Framework에서 데이터베이스에 연결해보십시오.), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/asny23/items/a2f429134a543f6fa068텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)