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
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
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 :)
Saludos!
Aqui tienes un ejemplo sencillo.
http://wiki.netbeans.org/SpanishTranslationTutorialesAPIPersistenciaVWP