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 aplicación 

Esperamos que se inicie GlassFish y se cargue la aplicación
Este se ejecutara en nuestro servidor local y…

Cambiando el estado de un checkbox

Cambiando el Estado de un CheckBox
Algunas veces deseamos controlar el estado de un checkbox o cambiarlo segùn determinadas condiciones.

Pasos:

1. Creamos un proyecto Web.

2. En el diseñador agregamos un checkbox y dos botones.

* Dar click derecho en el checkbox y luego seleccionar Add Binding Attribute, para agregar los atributos al checkbox, de manera que los podamos usar en nuestro código.

Generando automáticamente

private Checkbox checkbox1 = new Checkbox();

public Checkbox getCheckbox1() {
return checkbox1;
}

public void setCheckbox1(Checkbox c) {
this.checkbox1 = c;
}

3.Damos click derecho en el botón Habilitar, y seleccionamos Edit Action Event Handler.

A continuación, agregamos el código: this.checkbox1.setSelected(true);, el método setSelected con valor true, marca el checkbox como seleccionado, y un valor de false, quita la marca.

public String button1_action() {
// TODO: Process the action. Return value is a navigation
// case name where …

Un ejemplo sencillo de Refactorización y Genericos

Un ejemplo sencillo de Refactorización y Genericos

public class Refactorizador<K, V> {

    public V copyFromBeans(K k, V v) {
        try {
            Class claseK = k.getClass();
            Class claseV = v.getClass();

            Method[] metodosK = claseK.getMethods();

            for (Method method : metodosK) {
                if (isGetter(method)) {
                    Method metodoGetK = claseK.getDeclaredMethod(method.getName());
                    Method metodoSetV = claseV.getDeclaredMethod(changeGetBySet(method.getName()), method.getReturnType());
                    metodoSetV.invoke(v, metodoGetK.invoke(k));
                }

            }

        } catch (Exception e) {
            System.out.println("refactorizador() " + e.getLocalizedMessage());
        }
        return v;
    }

     public  boolean isGetter(Method method) {

        if (!method.getName().startsWith("get")) {
            return false;
        }
        if (method.getName().startsWith("getCla…