Tengo una consulta, tengo una tabla con los siguientes atributos
pe_documento
pe_nombres
pe_apellido_p
pe_apellido_m
Y quiero hacer una búsqueda desde un input de un nombre o número de documento
Estoy usando Primefaces e Hibernate y la base de datos en mysql
Esta búsqueda debe soportar coincidencias por ejemplo:
En el input (con n número de palabras a buscar):
Martín
Resultados:
Martin
martíN
En el input:
Donofrio
Resultados:
D’onofrio
donofrio
En el input:
Juan (nombres) Perez (apellido paterno o materno)
Resultados:
Juan Antonio Mariscal Peres
Juan Ruperto Péres
Como solución momentánea hice lo siguiente.
Código PHP:
StringTokenizer st = new StringTokenizer(posNombre);
List<String> busqueda = new ArrayList<String>();
while (st.hasMoreTokens()) { // este ciclo es para comprobar cuando
// se
// acaba de procesar tu cadena
String palabra = st.nextToken();// esto lee la palabra siguiente
// en
// la cadena
palabra = removeTildes(palabra);
// cadenaBD = cadenaBD.replaceAll(" ", "");
palabra = palabra.replaceAll("'", "");
palabra = palabra.replaceAll("-", "");
palabra = palabra.toLowerCase();
busqueda.add(palabra);
}
List<Postulante> postulanteDB = postulanteDao.listarPostulante();
listaCoincidenciasPostulantes = new ArrayList<Postulante>();
String cadenaBD;
for (Postulante p : postulanteDB) {
cadenaBD = p.getPersona().getPeNombres() + " "
+ p.getPersona().getPeApellidoP() + " "
+ p.getPersona().getPeApellidoM();
cadenaBD = removeTildes(cadenaBD);
cadenaBD = cadenaBD.replaceAll(" ", "");
cadenaBD = cadenaBD.replaceAll("'", "");
cadenaBD = cadenaBD.replaceAll("-", "");
cadenaBD = cadenaBD.toLowerCase();
int contador = 0;
int tamanio = busqueda.size();
for (String b : busqueda) {
if (p.getPersona().getPeDocumento().indexOf(b) != -1) {
listaCoincidenciasPostulantes.add(p);
break;
} else {
if (cadenaBD.indexOf(b) != -1) {
contador++;
if (tamanio == contador) {
listaCoincidenciasPostulantes.add(p);
break;
}
}
}
}
}
GRACIAS.