[英]How to implement JPA in Play Framework in a standard way
我已经通过https://www.playframework.com/documentation/2.5.x/JavaJPA
但这并不像是标准方法。 我想在persistence.xml
而不是application.conf中填充我的jdbc连接
像这样
<?xml version="1.0" encoding="UTF-8" ?>
<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" xmlns="http://java.sun.com/xml/ns/persistence">
<persistence-unit name="TestPersistence"
transaction-type="RESOURCE_LOCAL">
<class>com.example.pojo.Employee</class>
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<non-jta-data-source>DefaultDS</non-jta-data-source>
<properties>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url"
value="jdbc:mysql://localhost:3306/jpadb" />
<property name="javax.persistence.jdbc.user" value="root" />
<property name="javax.persistence.jdbc.password"
value="mukesh" />
<!-- EclipseLink should create the database schema automatically -->
<property name="eclipselink.ddl-generation" value="create-tables" />
<property name="eclipselink.ddl-generation.output-mode"
value="database" />
</properties>
</persistence-unit>
</persistence>
而不是像在application.conf中填充jdbc连接
db.default.driver=com.mysql.jdbc.Driver
db.default.url="jdbc:mysql://localhost:3306/jpadb"
db.default.user=root
db.default.password="mukesh"
db.default.jndiName=DefaultDS
jpa.default=TestPersistence
另外,如果没有其他方法可以在persistence.xml中获得jdbc连接,我们如何在application.conf中定义多个jdbc连接。 就像如果我有一个用于用户的mysql和用于帖子的oracle db。
注意:发布的源代码只是从公共域中复制的虚拟文件,以显示简短的问题。
您不必使用Play的数据库模块。 您可以定义自己的模块,然后加载数据库连接并独立运行它。
我将以https://github.com/playframework/play-isolated-slick为例,在这里-UserDAO在Play模块中绑定到SlickDAO:
https://github.com/playframework/play-isolated-slick/blob/master/modules/play/app/Module.scala#L19
并且提供了数据库提供程序:
https://github.com/playframework/play-isolated-slick/blob/master/modules/play/app/Module.scala#L27
但您不必使用Database.forConfig("myapp.database")
-您可以定义自己喜欢的任何配置。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.