2011-12-09 11 views
7

Al principio de mi proyecto estaba usando una combinación de Hibernate 3.3.2, openJPA 2.1.1 para conectarme a la base de datos y recuperar la información de la tabla. Ahora quiero eliminar Hibernate y usar openJPA para hacer la conexión y recuperar la información.configuración de persistence.xml de openJPA

Mi configuración anterior de persistence.xml era

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.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 persistence_2_0.xsd"> 
<persistence-unit name="test" transaction-type="RESOURCE_LOCAL"> 
    <provider>org.hibernate.ejb.HibernatePersistence</provider> 
     <properties> 
     <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/> 
     <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/> 
     <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> 
     <property name="hibernate.connection.url" value="jdbc:mysql://10.10.10.10:3306/test?autoReconnect=true"/> 
     <property name="hibernate.connection.username" value="user"/> 
     <property name="hibernate.connection.password" value="pwd"/> 
     <property name="hibernate.generate_statistics" value="true"/> 
     <property name="hibernate.cache.provider_class" value="org.hibernate.cache.OSCacheProvider"/> 
     <property name="hibernate.cache.use_second_level_cache" value="true"/> 
     <property name="hibernate.show_sql" value="true"/> 
     <property name="hibernate.format_sql" value="true"/> 
     <property name="hibernate.c3p0.min_size" value="5"/> 
     <property name="hibernate.c3p0.max_size" value="20"/> 
     <property name="hibernate.c3p0.timeout" value="1800"/> 
     <property name="hibernate.c3p0.max_statements" value="50"/> 
     <property name="hibernate.c3p0.idle_test_period" value="1800"/> 
     <property name="c3p0.idleConnectionTestPeriod" value="1810"/> 
     </properties> 
    </persistence-unit> 
</persistence> 

Ahora quiero pasar a OpenJPA 2.1.1 y para que mi archivo persistence.xml se

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.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_2_0.xsd"> 
<persistence-unit name="TestOpenJPAPersistence" transaction-type="RESOURCE_LOCAL"> 
    <provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider> 
    <properties> 
     <property name="javax.persistence.jdbc.url" value="jdbc:mysql://10.10.10.10:3306/test?autoReconnect=true"/> 
     <property name="javax.persistence.jdbc.user" value="user"/> 
     <property name="javax.persistence.jdbc.password" value="pwd"/> 
     <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/> 
     <property name="openjpa.ConnectionFactoryProperties" value="MaxActive=10,MaxIdle=5,MinIdle=2,MaxWait=1800000"/> 
     <property name="openjpa.Log" value="File=E:\\temp\\TestOpenJPAPersistence\\org.apache.openjpa.log, DefaultLevel=DEBUG, Runtime=INFO, Tool=INFO, SQL=TRACE"/> 
     <property name="openjpa.jdbc.DBDictionary" value="org.apache.openjpa.jdbc.sql.MySQLDictionary"/> 
     <property name="openjpa.DataCache" value="true"/> 
     <property name="openjpa.QueryCache" value="true"/> 
    </properties> 
</persistence-unit> 
</persistence> 

Mi pregunta es ¿cuáles son la propiedad de reemplazo para la siguiente propiedad de hibernación en openJPA

<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> 
<property name="hibernate.cache.provider_class" value="org.hibernate.cache.OSCacheProvider"/> 
<property name="hibernate.cache.use_second_level_cache" value="true"/> 
<property name="hibernate.show_sql" value="true"/> 
<property name="hibernate.format_sql" value="true"/> 
<property name="hibernate.c3p0.min_size" value="5"/> 
<property name="hibernate.c3p0.max_size" value="20"/> 
<property name="hibernate.c3p0.timeout" value="1800"/> 
<property name="hibernate.c3p0.max_statements" value="50"/> 
<property name="hibernate.c3p0.idle_test_period" value="1800"/> 

+1

Sin ofender, pero el número de los parámetros que dio sugiere la actitud: "Hazlo por mí", y no "Ayúdame, estoy atrapado con ...". Cuente con suerte si alguien proporciona la lista completa. – MaDa

Respuesta

9

Después de muchos intentos de prueba y error, he encontrado algunos parámetros de reemplazo. Mi archivo persistence.xml presente parece

persistence.xml:

<provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider> 
<properties> 
    <property name="openjpa.ConnectionURL" value="jdbc:mysql://xx.xx.xx.xx:3306/dbname"/> 
    <property name="openjpa.ConnectionDriverName" value="com.mysql.jdbc.Driver"/> 
    <property name="openjpa.ConnectionUserName" value="xxx"/> 
    <property name="openjpa.ConnectionPassword" value="xxx"/> 
    <property name="openjpa.DynamicEnhancementAgent" value="true"/> 
    <property name="openjpa.RuntimeUnenhancedClasses" value="supported"/> 
    <property name="openjpa.Log" value="SQL=TRACE"/> 
    <property name="openjpa.ConnectionFactoryProperties" value="PrettyPrint=true, PrettyPrintLineLength=72, PrintParameters=true, MaxActive=10, MaxIdle=5, MinIdle=2, MaxWait=60000"/> 
</properties> 

Para la agrupación de conexiones check información y para todas las propiedades OpenJPA check

Esperanza esto ayuda

+1

+1 para el enlace a todas las propiedades, gracias =) – earcam

Cuestiones relacionadas