我正在使用 JPA,我想使用 JTA。
DataSource 和 JNDI 已正确设置并正常工作,但如果数据库为空(尚未创建表)JTA 不工作!
这就是我的意思。如果我使用以下persistence.xml:
<?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_1_0.xsd"
version="1.0">
<persistence-unit name="MyUnit" transaction-type="JTA">
<jta-data-source>jdbc/MyDB</jta-data-source>
<class>de.MyEntity</class>
</persistence-unit>
</persistence>
它说 MyEntity 不是实体。EntityManager 找不到它。
如果我使用这个 persistence.xml 来构建数据库并导入数据:
<?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_1_0.xsd"
version="1.0">
<persistence-unit name="MyUnit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>de.MyEntity</class>
<properties>
<property name="persistence-context.persist-on-commit" value="true"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/myDatastore" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"></property>
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
<property name="hibernate.connection.password" value="admin" />
<property name="hibernate.connection.username" value="admin" />
<property name="hibernate.hbm2ddl.auto" value="update"/>
</properties>
</persistence-unit>
</persistence>
效果很好!如果我现在切换回上面的 persistence.xml 突然使用 JTA,他能够找到 MyEntity 作为 EntityManager 的一个实体.....
那么这里的意义在哪里?如果我想使用 entitymanager 和 jta 创建我的数据库,它不起作用,但如果我不使用 jta 创建它并在突然创建所有内容时切换回 jta,我可以使用 jta,他不会抱怨。