Skip to main content

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.

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!

Popular posts from this blog

Tutorial básico de aplicaciones Web con NetBeans parte 1

NetBeans ofrece un excelente soporte para el desarrollo de aplicaciones Web, en esta ocasión lo haremos utilizando el Framework Java Server Faces 2.0. En el Menu Seleccionamos Nuevo->Proyecto y luego en Categorias Java Web y en tipo de Proyectos Web  Application indicamos el nombre del proyecto Seleccinamos el servidor Web, usamos GlassFish ya que este soporta EJB3.0 y JSF 2.0 Framework Java Server Faces El IDE genera el esquelto del proyecto Web Pages   almacenamos las paginas .html, xhtml, jsf, los archivos de recursos, los scripts .js, imagenes Source Packages    Son las clases Java  Test Packages    Son las clases que usamos para los Test Libraries     Tenemos las bibliotecas de Java y GlassFish necesarias para ejecutar la aplicación Web. Test Libraries     Están las bibliotecas usadas para los test  Configuration Files    Archivos de configuración de la aplicación. Ejecutamos la...

Test con JUnit

El viernes dicte un taller en el que conversábamos sobre Tecnologías Java y luego desarrollamos una aplicación muy básica para demostrar como utilizar JUnit con NetBeans. Pasos: 1. Crear un proyecto Desktop con NetBeans 2. Crear una clase llamada Operaciones 3. Diseñados un formulario y agregramos componentes de manera que quede similar a la figura Código de los botones try { double a = Double.parseDouble(jTextField1.getText()); double b = Double.parseDouble(jTextField2.getText()); Operaciones operaciones = new Operaciones(); double r = operaciones.Sumar(a, b); jTextField3.setText(String.valueOf(r)); } catch (Exception ex) { JOptionPane.showMessageDialog(this, ex.getMessage().toString()); } 4. Creamos los test Seleccionamos las clases En el menu Herramientas,seleccionamos Crear pruebas JUnit Seleccionamos la versión de JUnit En la ventana siguiente seleccionamos los parámetros para nuestras pruebas . Le quitamos la selección a Probar Inicializador y Probar Finalizador NetBeans crea las...

JUnit con DataClassG

JUnit con DataClassG 0. ESQUEMA Services: Por cada beans crearemos una clase Services que se encargará de interactuar con el controller para realizar las operaciones de la base de datos. Se crearan los métodos insert, update,delete y los demas metodos para realizar las diversas operaciones. Test: Se crearán las clases para test de las clases Services. Form: Los formularios para la interactuar con el usuario. ProvinciasServices.java colocamos los métodos, insert, update,delete public class ProvinciasServices {    ProvinciasController provinciasController = new ProvinciasController();    public ProvinciasServices() {    }    public Boolean insert (Provincias provincias){        try{            if(provinciasController.insert(provincias)){              return tru...