Monday, July 07, 2008

distinct con JPA


Trabajando en un codigo sobre JPA con mi amigo Roberto, se habia creado un nombre de campo como este ejemplo:
apellido_paterno
El entity se genera como apellidoPaterno (es decir se eliminara el _ del nombre del campo y se tomara la primera letra en mayuscula), de manera que cuando lo utilicemos en un createQuery, siempre debemos verificar el nombre correcto para el objeto.
javax.persistence.Query q = em.createQuery("SELECT distinct p.apellidoPaterno from Paciente as p ORDER BY p.apellidoPaterno");

Aqui un segmento de codigo para usar dinamicamente un distinct, y cargar un dropdown.
Declarar en el SessionBean.
private Option OptionApellidoPaterno[];

public void getListadoApellidoPaterno() {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("MedicinaAppPU");
EntityManager em = emf.createEntityManager();
try {
javax.persistence.Query q = em.createQuery("SELECT distinct p.apellidoPaterno from Paciente p ORDER BY p.apellidoPaterno");
List list = (List) q.getResultList();

OptionApellidoPaterno = new Option[list.size()];
for (int i = 0; i < list.size(); i++) {
String x = (String)list.get(i);
OptionApellidoPaterno[i] = new Option(x, x);
}

} finally {
em.close();
}
}

Luego simplemente hacemos binding del dropdown con el OptionApellidoPaterno.

8 comments:

Anonymous said...

Hola!

No entiendo muy bien de que va tu articulo. Si lo que quieres mostrar es como tener una columna de la tabla con un nombre y otra en la entidad con otro, para ello haria falta la anotacion correspondiente que indicase al framework JPA que uses el mapeo, algo como:

@Column(name = "apellido_paterno")

Una cosa mas, cuando creas el objeto Query y dices "from Paciente as p" el as no es necesario.

Saludos

avbravo said...

gracias por lo del as, se ma habia pasado depurarlo, lo del campo, solo era para indicar cuando el IDE genera el entity directamente, solo como un comentario para indicar eso, un placer recibir tus comentarios.

Anonymous said...

Ajam, entonces para generar un Entity usas netbeans haciendo ingenieria inversa de la tabla?

Perdona pero por saber ... nunca he suado netbeans para JPA.

Si es asi, que framework de persistencia usa netbeans por defecto para JPA?

Un saludo :)

avbravo said...

No te preocupes amigo al contrario un placer tener tus comentarios, un saludo desde panama.

Anonymous said...

Entonces puedes responder a las preguntas :P

Saludos!

avbravo said...

Puedes usar TopLink amigo.
Aqui tienes un ejemplo sencillo.
http://wiki.netbeans.org/SpanishTranslationTutorialesAPIPersistenciaVWP

avbravo said...

puedes escribirme avbravo@gmail.com

Antonio de Mora said...

netbeans usa eclipse link. Una chulada, a penas comienzo con esto del ORM y es de lo mejor!

Entrevista con Geovany Mendoza

Entrevista con Geovany Mendoza En esta ocasión continuamos con las entrevistas a miembros importantes de la comunidad Java, la realizare ...