Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 07-09-2004
tin tin is offline
Miembro
 
Registrado: ago 2003
Ubicación: Palma de Mallorca
Posts: 10
Poder: 0
tin Va por buen camino
Problemas con los Collation Drivers.

Hola a todos.
Este es un mensaje que continua un hilo que inicié hace unos meses sobre los Collation Drivers de Interbase.
El problema tiene que ver con los acentos en campos Varchar en Interbase.

El driver ES_ES funciona bien siempre que sea comparación exacta es decir.

Código:
select * from EMPLEADO where apellido='Perez' COLLATE ES_ES
Esto me devuelve Pérez,PErez,Pèrez.... es decir perfecto.

El problema surge cuando utilizo la clausula LIKE

Código:
select * from EMPLEADO where apellido LIKE '%Perez%' COLLATE ES_ES
Que es lo que debo usar para buscar en un campo que contiene nombre y apellidos.

En este caso no funciona y unicamente me devuelve los Perez sin acento.

Si alguien tiene experiencia en este campo agradecería una ayuda.

Saludos.

Última edición por tin fecha: 07-09-2004 a las 12:47:40.
Responder Con Cita
  #2  
Antiguo 07-09-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 23
guillotmarc Va por buen camino
Hola.

Prueba con :

select * from EMPLEADO where apellido containing 'Perez' COLLATE ES_ES

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 07-09-2004
tin tin is offline
Miembro
 
Registrado: ago 2003
Ubicación: Palma de Mallorca
Posts: 10
Poder: 0
tin Va por buen camino
Problema resuelto

Pues ya lo he resuelto, ha sido un poco laborioso pero se ha resuelto:

He creado una UDF que me convierte 'é' en 'e' por ejemplo.

de esta forma la consulta

SELECT * FROM T_EMPLEADO WHERE F_ACC(NOMBRE) LIKE '%Perez%';

Funciona perfecta y me devuelve lo que me tiene que devolver.

Gracias por las sugerencias Marc.

PD:_ Si alguien quiere la UDF que me diga cosas.

Saludos.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 23:37:34.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi