Foros del Web » Programando para Internet » PHP »

MySQL y la Letra Ñ

Estas en el tema de MySQL y la Letra Ñ en el foro de PHP en Foros del Web. Hola de nuevo, Tras hacer una serie de pruebas he comprobado, que cuando lanzo una consulta sobre MySQL para realizar busquedas en cadenas de texto, ...
  #1 (permalink)  
Antiguo 19/08/2004, 02:13
 
Fecha de Ingreso: febrero-2003
Mensajes: 47
Antigüedad: 21 años, 2 meses
Puntos: 0
MySQL y la Letra Ñ

Hola de nuevo,

Tras hacer una serie de pruebas he comprobado, que cuando lanzo una consulta sobre MySQL para realizar busquedas en cadenas de texto, no recibo los resultados apropiados si la cadena a buscar contiene la letra 'Ñ', puede ser cierto?

Utilizo lo siguiente en la clausula where: campo_texto LIKE '%ñ%'.

La busqueda me suele devolver un número mayor de registros al lógico, incluyendo registros donde no aparece está letra.
Puede ser verdad?
Gracias.
  #2 (permalink)  
Antiguo 19/08/2004, 06:51
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 22 años, 3 meses
Puntos: 129
Lo que sucede es que usando el tipo de campo que definistes para tu "campo_texto" .. Mysql no está "asimilando" una ñ (eñe) por un n .. tampoco distingue entre caracteres acentuados.

Si deseas "forzar" a Msyql para que busque y distinga entre carcteres como ñ, acentuados .. etc debes definir el campo en cuestión con propiedad "BINARY" o forzar esa consulta SQL concreta con el operador "BINARY" ..

http://dev.mysql.com/doc/mysql/en/Ca...Operators.html
(Ojo por qué esto también distingirá entre mayusculas y minusculas. Para evitar esto último en el link del manual oficial de Mysql se describe como hacer condicionales para comparar todo en mayusculas o minusculas forzando)


Un saludo,
  #3 (permalink)  
Antiguo 19/08/2004, 07:24
 
Fecha de Ingreso: febrero-2003
Mensajes: 47
Antigüedad: 21 años, 2 meses
Puntos: 0
gracias Cluster
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 11:18.