Ver Mensaje Individual
  #1 (permalink)  
Antiguo 13/05/2015, 04:45
Avatar de TamyZamb
TamyZamb
 
Fecha de Ingreso: mayo-2015
Mensajes: 6
Antigüedad: 8 años, 11 meses
Puntos: 0
Comprobar que el contenido de un array se cuentra en otro array

Hola chic@s!

Quiero hacer una consulta a la base de datos, pero quiero que si al escribir las palabras en desorden igualmete lo acepte y me lo imprima. Quiero decir:

Los nombre que tengo en la base de datos son algo como: Maria-Lopez o Laura Marin...

Yo quiero que si pongo: Lopez Maria o Marin Laura, también el "SELECT" me muestre el resultado.

Entonces pensé meter en un array lo que recojo del formulario y lo que me devuelva el select. Después comprar ambos arrays y si los campos del array del formulario están en array del select, mostrar la consulta.


// Recojo la variable del formulario
$name = $_POST['name'];

// Meto cada palabra en un array
$arname= explode (" ",$name);

//HAgo la consulta a la base de datos
$sqlselect = "SELECT * FROM offers";
$result = db_query($sqlselect);

//Función para separar no solo por cada espacio, sino por cada guión también
function multiexplode ($delimiters,$string) {
$ready = str_replace($delimiters, $delimiters[0], $string);
$launch = explode($delimiters[0], $ready);
return $launch;
}


//Recorro la consulta
while($row = $result->fetch_assoc()) {
//Separo las palabras de cada consulta y los meto en un array
$arselect = multiexplode(array(" ","-"),$row["name"]);


//Aquí es donde viene la duda

//Recorro el primer array y lo voy comprobando con el segundo
foreach($arname as $valor){ if(array_search($valor,$arselect) !== false){
print_r ($arname);
print_r ($arselect);
echo "Funciona";
}else{
print_r ($arname);
print_r ($arselect);
echo "Probando</td></tr>";
}
}
}



*** El problema que tengo que es que me muestra cualquier consulta que tenga alguno de los campos del array formulario, yo solo quiero los nombre que tengan todos los campos del array formulario.

** He probrado con las funciones in_array() y search_array (), y tampoco me funcionaron, no sé si es que no sé usarlas bien...

Mil gracias de antemano