Foros del Web » Programando para Internet » PHP »

¿Comparaciones LIKE como MySQL en PHP?

Estas en el tema de ¿Comparaciones LIKE como MySQL en PHP? en el foro de PHP en Foros del Web. Hola! Veréis tengo un problemilla. Voy a poneros el caso reduciéndolo a lo simple: Tengo, para empezar: -Una base de datos mysql con una tabla ...
  #1 (permalink)  
Antiguo 16/11/2009, 05:52
 
Fecha de Ingreso: noviembre-2009
Mensajes: 19
Antigüedad: 14 años, 5 meses
Puntos: 1
¿Comparaciones LIKE como MySQL en PHP?

Hola!
Veréis tengo un problemilla. Voy a poneros el caso reduciéndolo a lo simple:

Tengo, para empezar:
-Una base de datos mysql con una tabla con campos nombre y apellidos.
- Un formulario con un input text en el que el usuario mete algo del nombre del autor (una parte del nombre o del apellido o del nombre +apellido).

En el proceso de análisis del formulario el objetivo es reconocer a la persona para realizar después otras cosas.

De no ser porque en la base de datos son dos campos y en el formulario solo 1 podría usar el LIKE de mysql. Podría poner 2 campos en el form, o cambiar la base de datos poniendo solo un campo llamado nombreaps, pero no quiero hacer eso, así que decido intentarlo de otra manera:

- Extraigo de la base de datos todos los nombres y apellidos de todas las tuplas.

- En un while uno en $nombreaps el contenido de los dos campos.

- El objetivo es comparar $nombreaps con el $_POST[‘nombreaps’] pero PROBLEMA: No conozco en php un operador relacional semejante al LIKE de mysql.

A ver si me echais un cable. Gracias!
  #2 (permalink)  
Antiguo 16/11/2009, 05:55
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años
Puntos: 839
Respuesta: ¿Comparaciones LIKE como MySQL en PHP?

Es mucho más eficiente realizar las comparaciones directamente en la base de datos. Podrías hacer algo como:
Código MySQL:
Ver original
  1. SELECT nombre, apellido FROM tabla WHERE nombre LIKE '%texto%' OR apellido LIKE '%texto%';
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
  #3 (permalink)  
Antiguo 16/11/2009, 05:59
Avatar de .php  
Fecha de Ingreso: julio-2006
Mensajes: 481
Antigüedad: 17 años, 9 meses
Puntos: 5
Respuesta: ¿Comparaciones LIKE como MySQL en PHP?

lo q entendi deseas haces una busqueda con un textfield a dos campos.

te lo voy a resumir en español, por es solo sql-

Código:
selecciona todo el formulario XXX donde CAMPO1 contenga $var O CAMPO2 contenga $var
ahora esto en sql seria algo asi, te dejaria la tarea a q lo pases a sql, pero lo hago en un rato
Código:
$var = $_POST['txt_search'];
$sql = "select * from XXX where CAMPO1 like '%$var%' or CAMPO2 like '%$var%'";
__________________
~~[FiDeLio]~~
  #4 (permalink)  
Antiguo 16/11/2009, 07:10
 
Fecha de Ingreso: noviembre-2009
Mensajes: 19
Antigüedad: 14 años, 5 meses
Puntos: 1
Respuesta: ¿Comparaciones LIKE como MySQL en PHP?

sí sí, eso ya lo tengo claro, lo que pasa es que $_POST['txt_search'], como tu lo llamas puede contener tanto el nombre como el apellido como los dos a la vez. por ejemplo

Base de datos:
-Nombre: Arturo
-Apellidos: Perez Reverte

y el formulario puede mandar algo asi como

$_POST['txt_search'] = arturo per

así que no es tan simple como eso ^^
  #5 (permalink)  
Antiguo 16/11/2009, 07:32
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años
Puntos: 839
Respuesta: ¿Comparaciones LIKE como MySQL en PHP?

Si quieres unir el contenido de ambos campos para realizar la comparación puedes hacerlo también desde la misma consulta:
Código MySQL:
Ver original
  1. SELECT ... FROM ... WHERE CONCAT(nombre, apellido) LIKE '%texto%';
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
  #6 (permalink)  
Antiguo 16/11/2009, 08:26
 
Fecha de Ingreso: noviembre-2009
Mensajes: 19
Antigüedad: 14 años, 5 meses
Puntos: 1
Respuesta: ¿Comparaciones LIKE como MySQL en PHP?

Cita:
Iniciado por David Ver Mensaje
Si quieres unir el contenido de ambos campos para realizar la comparación puedes hacerlo también desde la misma consulta:
Código MySQL:
Ver original
  1. SELECT ... FROM ... WHERE CONCAT(nombre, apellido) LIKE '%texto%';
wooow no sabia que existiera esa funcion en mysqlª! gracias
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Tema Cerrado

SíEste tema le ha gustado a 1 personas




La zona horaria es GMT -6. Ahora son las 07:10.