統合JPA
1.でconf/application.conf
db.epay.driver=com.mysql.jdbc.Driver
db.epay.url="jdbc:mysql://localhost:3306/epay"
db.epay.user=root
db.epay.password="1234"
db.epay.jndiName=epayDS
hibernate.use_sql_comments=true
jpa.default=defaultPersistenceUnit
データベースが存在しない場合は、データベース
2に手動で新しいデータベースを作成してください 。project/ build.scalaで
val appDependencies = Seq(
// Add your project dependencies here,
javaCore,
javaJdbc,
javaEbean,
"mysql" % "mysql-connector-java" % "5.1.18",
"org.hibernate" % "hibernate-entitymanager" % "3.6.9.Final",
"play" % "play-java-jpa_2.10" % "2.1.0"
)
3.次に、正しいJPA構成ファイルpersistence.xmlを作成します。それをconf / META-INFディレクトリに置きます(そうでない場合は新しいものを作成します)
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="defaultPersistenceUnit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<non-jta-data-source>epayDS</non-jta-data-source>
<properties>
<property name="hibernate.hbm2ddl.auto" value="update" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect" />
</properties>
</persistence-unit>
</persistence>
注:persistence-unit名は
application.conf
jpa.default値にあり、非jta-data-sourceはdb.epay.jndiNameです。
4.Javaクラス
import play.db.jpa.*;
public class UserControl extends Controller {
final static Form<User> userForm = form(User.class);
@Transactional
public static Result register() {
// DataSource ds = DB.getDataSource("epay");
// try {
// System.out.println("conn:"+!ds.getConnection().isClosed());
// } catch (SQLException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
return ok(form.render());
}
@Transactionalをメソッドに追加します。
テストを開始して、エラーがあるかどうかを確認します。