Ver Mensaje Individual
  #5 (permalink)  
Antiguo 25/03/2012, 18:54
vindacochea
 
Fecha de Ingreso: enero-2012
Ubicación: Guayaquil
Mensajes: 3
Antigüedad: 12 años, 3 meses
Puntos: 1
Mensaje Respuesta: Configuracion de JPA EclipseLink

Que tal Joseprox, te indico los pasos que realizé en mi aplicación Swing con JPA, lo hice en Netbeans:

1. En la pestaña de Servicios, Databases, drivers, cree una nueva conexion usando Mysql (click derecho -- conecting ussing..).
2. Una vez creada la conexion, en mi proyecto, click derecho, new -> persistent unit, ahi escoges la conexion que acabas de crear en la pestaña de servicios.
3. Una vez creada la unidad de persistencia, se crea el archivo persistence.xml con los parametros de conexión, y cada vez que crees una clase entidad se va a agregar la referencia de esa clase en este archivo persistence.xml. Al final mi archivo persistence.xml quedó de la siguiente manera:

Código XML:
Ver original
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <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">
  3.   <persistence-unit name="DefinicionesSmsPU" transaction-type="RESOURCE_LOCAL">
  4.     <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
  5.     <class>Entidad.Usuarios</class>
  6.     <class>Entidad.Alumnos</class>
  7.     <class>Entidad.Nivel</class>
  8.     <class>Entidad.Materias</class>
  9.     <class>Entidad.Paralelos</class>
  10.     <properties>
  11.       <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/comunicacion_sms"/>
  12.       <property name="javax.persistence.jdbc.password" value="admin"/>
  13.       <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
  14.       <property name="javax.persistence.jdbc.user" value="root"/>
  15.     </properties>
  16.   </persistence-unit>
  17. </persistence>

4. Con esto ya puedes utilizar tu aplicación con JPA, invocando la unidad de persistencia desde tu codigo java:
Código Java:
Ver original
  1. public String PU = "Motor_Emai_y_SMSPU";
  2. EntityManagerFactory emf = Persistence.createEntityManagerFactory(PU);
  3. EntityManager em = emf.createEntityManager();

5. De aquí viene la parte para hacer que la conexión sea dinámica, primero cuando inicio la aplicacion, levanto una ventana que me pide los datos de conexion a la base, y estos datos los guardo en un archivo llamado conexion.conf.
Código Java:
Ver original
  1. private Properties prop = new Properties();
  2. OutputStream propOut = null;
  3. try {
  4.             prop.setProperty("servidor", this.jTxtServidor.getText().trim());
  5.             prop.setProperty("puerto", this.jTxtPuerto.getText().trim());
  6.             prop.setProperty("password", this.jTxtPassword.getText().trim());
  7.             prop.setProperty("usuario", this.jTxtUser.getText().trim());
  8.             prop.setProperty("base", this.jTxtBase.getText().trim());
  9.             propOut = new FileOutputStream(new File(System.getProperty("user.dir") + "\\conexion.conf"));
  10.             prop.store(propOut, "Conexion");
  11.             propOut.close();
  12.         } catch (Exception e) {
  13.             System.out.println(e.getMessage());
  14.         }

6. Una vez que ya tenga el archivo creado, inicio mi aplicacion leyendo el archivo conexion.conf, utilizando sus datos para crear el EntityManagerFactory.

Código Java:
Ver original
  1. FileInputStream in = null;
  2.         try {
  3.             Properties prop = new Properties();
  4.             Map con = new HashMap();
  5.             in = new java.io.FileInputStream(System.getProperty("user.dir") + "\\conexion.conf");
  6.             if (in != null) {
  7.                 prop.load(in);
  8.                 if (prop != null) {
  9.                     String server = "jdbc:mysql://" + prop.getProperty("servidor", "").trim()
  10.                             + ":" + prop.getProperty("puerto", "").trim() + "/" + prop.getProperty("base", "").trim();
  11.                     con.put("javax.persistence.jdbc.url", server);
  12.                     con.put("javax.persistence.jdbc.password", prop.getProperty("password", "").trim());
  13.                     con.put("javax.persistence.jdbc.user", prop.getProperty("usuario", "").trim());
  14.                 }
  15.             }
  16.             private EntityManagerFactory emf; = Persistence.createEntityManagerFactory(PU, prop);
  17.             private EntityManager em = emf.createEntityManager();
  18.            
  19.         } catch (Exception e) {            
  20.             System.out.println(e.getMessage());
  21.         }

7. Con eso ya tienes como hacer que la conexion sea dinamica, obviamente la ventana que guarda los datos de conexion en el archivo conexion.conf, solo se va a ejecutar la primera vez que se inicie la aplicacion que estas desarrollando, o cuando los parámetros que estén guardados sean incorrectos, estas validaciones tenlas presentes al desarrollar tu aplicación, aquí solo te expliqué lo que se necesita para que la conexión sea dinámica.

Espero haberte ayudado, si tienes dudas por favor me comunicas.