使用JPA的不同实现的配置 |
以往 使用JPA的实现是toplink,现在改为hibernate,所以要 批改persistence.xml文件,两者的配置有一些不一样,而且在EE环境下面和SE的环境下面也有不一样,还有丝毫,那便是当persistence.xml里面有些 格局出错的时候, 固然出错的不是我们需求的那个单元,但也会使得整个persistence.xml报废 。 下面帖的是在SE的环境下面 使用toplink和hibernate的实现,两者都写在同一个persistence.xml里面 。这样切换起来也容易一些 。 <?xml version="1.0" encoding="UTF-8"?> <persistence version="1.0" 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"> <persistence-unit name="TestSSH2PU" transaction-type="RESOURCE_LOCAL"> <provider>oracle.toplink.essentials.PersistenceProvider</provider> <class>com.hadeslee.jpaentity.Department</class> <class>com.hadeslee.jpaentity.Person</class> <properties> <property name="toplink.jdbc.user" value="sa"/> <property name="toplink.jdbc.password" value="hadeslee"/> <property name="toplink.jdbc.url" value="jdbc:microsoft:sqlserver:// localhost:1433;DatabaseName=testSSH"/> <property name="toplink.jdbc.driver" value="com.microsoft.jdbc.sqlserver.SQLServerDriver"/> <property name="toplink.ddl-generation" value="create-tables"/> </properties> </persistence-unit> <persistence-unit name="TestSSH1PU2" transaction-type="RESOURCE_LOCAL"> <provider>org.hibernate.ejb.HibernatePersistence</provider> <class>com.hadeslee.jpaentity.Department</class> <class>com.hadeslee.jpaentity.Person</class> <properties> <property name="hibernate.connection.driver_class" value=" com.microsoft.jdbc.sqlserver.SQLServerDriver"/> <property name="hibernate.connection.url" value=" jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=testSSH"></property> <property name="hibernate.connection.username" value="sa"></property> <property name="hibernate.connection.password" value="hadeslee"></property> <property name="hibernate.show_sql" value="true"></property> <property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect"></property> <property name="hibernate.current_session_context_class" value="thread"></property> </properties> </persistence-unit> </persistence> 在SE的环境下面,是不能 使用容器的JTA的数据源的 。而且不能 使用<exclude-unlisted-classes>true</exclude-unlisted-classes>这个属性 。 本文重点是记录下两个常用的JPA的实现的配置 。目前是在SE环境下的配置 。EE环境下面的配置如下: <?xml version="1.0" encoding="UTF-8"?> <persistence version="1.0" 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"> <persistence-unit name="unit_mssql" transaction-type="JTA"> <provider>oracle.toplink.essentials.PersistenceProvider</provider> <jta-data-source>MobileOAMSSQL</jta-data-source> <properties> <property name="toplink.ddl-generation" value="create-tables"/> <property name="toplink.logging.level" value="FINE"/> </properties> </persistence-unit> <persistence-unit name="MyApp-ejbPU2" transaction-type="JTA"> <provider>org.hibernate.ejb.HibernatePersistence</provider> <jta-data-source>MobileOAMYSQL</jta-data-source> <properties> <property name="hibernate.hbm2ddl.auto" value="update"/> <property name="hibernate.show_sql" value="true"/> </properties> </persistence-unit> </persistence> 在EE环境下面 使用JPA配置就 容易了许多,首先他 可以把目前模块的CLASS文件都包含进来,不用手工指定 。而且也少了众多有对于数据库衔接的操作,由于这个时候都是从容器里面去取数据源的 。而且此时的事务是由容器去治理的,也便是 使用JTA,不再是RESOURCE_LOCAL了 。这样在代码里面就不用em.getTransaction() 。begin();和em.getTransaction() 。commit()了,而且 可以 使用注入 性能,把EntityManager注入到 使用它的地方了 。 |