Foros del Web » Programando para Internet » PHP »

Case-Sensitive

Estas en el tema de Case-Sensitive en el foro de PHP en Foros del Web. tengo un problema con el case sensitive al realizar un query de busqueda, lo que quiero es que no se considere si la variable tiene ...
  #1 (permalink)  
Antiguo 20/07/2010, 10:05
 
Fecha de Ingreso: mayo-2010
Mensajes: 212
Antigüedad: 14 años, 6 meses
Puntos: 3
Case-Sensitive

tengo un problema con el case sensitive al realizar un query de busqueda, lo que quiero es que no se considere si la variable tiene o no mayusculas al comparar.

Este seria el Query:
$incidencia = "SELECT F.Id_falta, F.Id_empleado, F.Fecha_falta, F.Justificacion, F.Registro_incapacidad FROM contra_desc_incidencias F";

$vNombre = $_REQUEST['vNombre'];
$vAPPA = $_REQUEST['vAPPA'];
$vAPMA = $_REQUEST['vAPMA'];
$vHOY = $_REQUEST['vHOY'];
$vJUSTO = $_REQUEST['vJUSTO'];
$vINCAPACIDAD = $_REQUEST['vINCAPACIDAD'];

$string = $vNombre."_".$vAPPA."_".$vAPMA."_".$vHOY."_".$vJUS TO."_".$vINCAPACIDAD;
$Datos = explode("_",$string);

//echo $string;
//var_dump($Datos);

$Nvals = array_filter($Datos);
$countNvals = count($Nvals);

IF($countNvals>=1)
{

$incidencia .= ", contra_empleados E WHERE E.Id_empleado = F.Id_empleado AND ";
IF($Nvals[0])
{
$incidencia .= " E.nombre LIKE '%$Nvals[0]%' ";
IF($countNvals > 1 AND $Nvals[0] != $Nvals[max(array_keys($Nvals))])
$incidencia .= " AND ";
}

IF($Nvals[1])
{
$incidencia .= "E.Apellido_Paterno LIKE '%$Nvals[1]%' ";
IF($countNvals > 1 AND $Nvals[1] != $Nvals[max(array_keys($Nvals))])
$incidencia .= " AND ";
}

IF($Nvals[2])
{
$incidencia .= "E.Apellido_Materno LIKE '%$Nvals[2]%' ";
IF($countNvals > 1 AND $Nvals[2] != $Nvals[max(array_keys($Nvals))])
$incidencia .= " AND ";
}

IF($Nvals[3])
{
$incidencia .= " F.fecha_falta LIKE '%$Nvals[3]%' ";
IF($countNvals > 1 AND $Nvals[3] != $Nvals[max(array_keys($Nvals))])
$incidencia .= " AND ";
}

IF($Nvals[4])
{
$incidencia .= " F.justificacion LIKE '%$Nvals[4]%' ";
IF($countNvals > 1 AND $Nvals[4] != $Nvals[max(array_keys($Nvals))])
$incidencia .= " AND ";
}

IF($Nvals[5])
{
$incidencia .= " F.Registro_incapacidad LIKE '%$Nvals[5]%' ";
}
}

$EmpBus = @mysql_query($incidencia);
__________________
Por favor dejenme Karmas
  #2 (permalink)  
Antiguo 20/07/2010, 10:12
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: Case-Sensitive

pues eso no se puede solucionar con PHP...

deberías investigar en alguna referencia de SQL al respecto...
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 20/07/2010, 10:20
Colaborador
 
Fecha de Ingreso: octubre-2009
Ubicación: Tokyo - Japan !
Mensajes: 3.867
Antigüedad: 15 años, 1 mes
Puntos: 334
Respuesta: Case-Sensitive

Código SQL:
Ver original
  1. SELECT datos FROM tabla WHERE UPPER(dato1) = UPPER(dato2)

si los dejas los 2 en mayúsculas puede servir ?
__________________
More about me...
~ @rhyudek1
~ Github
  #4 (permalink)  
Antiguo 20/07/2010, 11:12
 
Fecha de Ingreso: mayo-2010
Mensajes: 212
Antigüedad: 14 años, 6 meses
Puntos: 3
Respuesta: Case-Sensitive

Esa es buena idea. Asi no me complico con codigo.

Cita:
Iniciado por Hidek1 Ver Mensaje
Código SQL:
Ver original
  1. SELECT datos FROM tabla WHERE UPPER(dato1) = UPPER(dato2)

si los dejas los 2 en mayúsculas puede servir ?
__________________
Por favor dejenme Karmas
  #5 (permalink)  
Antiguo 20/07/2010, 11:14
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: Case-Sensitive

Cita:
Iniciado por Ursulo Ver Mensaje
Esa es buena idea. Asi no me complico con codigo.
por supuesto, y para la otra investiga en el lugar correcto...
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #6 (permalink)  
Antiguo 20/07/2010, 11:20
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años, 7 meses
Puntos: 839
Respuesta: Case-Sensitive

También te servirá investigar sobre la colación de caracteres de tu tabla:
http://dev.mysql.com/doc/refman/5.0/es/charset.html
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.

Etiquetas: Ninguno
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.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:46.