PDA

Ver la Versión Completa : Filtrado de datos con acentos


Josepo
18-01-2008, 14:08:20
Hola a todos,

Tengo un clientDataSet con un campo "Nombre" que puede tener acentos o no. Tengo un campo TEdit donde introduzco el nombre a buscar. El problema es que si no introduzco exactamente el filtro tal como fue escrito, no me lo localiza.

Ejemplo:

cds -> exiten Jose y José
filtro -> introduzco Jose
resultado -> muestra Jose y no muestra José.mi deseo es que al comparar no tenga en cuenta los acentos.

He creado un filtro de tipo:


cdsEditaCliente.Filtered:= False;
vFiltre:= 'Nombre = '''+ UpperCase(edClienteABuscar.Text)+'*''';
cdsEditaCliente.Filter := vFiltre;
cdsEditaCliente.Filtered := True;


¿Existe alguna función con la que poder comparar texto saltando el problema de los acentos? o alguna otra solución.

Trabajo con Delphi 7 y MySQL.

Gracias.

espericueta
18-01-2008, 16:23:52
esto funciona en sql server y creo que tambien en MySql

cdsEditaCliente.Filtered:= False;
vFiltre:= 'Nombre collate Modern_Spanish_CS_AI = '''+ UpperCase(edClienteABuscar.Text)+'*''';
cdsEditaCliente.Filter := vFiltre;
cdsEditaCliente.Filtered := True;

lee intercalaciones
http://technet.microsoft.com/es-es/library/ms143515.aspx

Josepo
21-01-2008, 17:50:48
Hola espericueta, gracias por tu aportación.

Las indicaciones que me das van orientadas a filtrar por SQL, pero el código que yo puse es un filtrado en el clientDataSet y no admite lo que me pones. En caso de hacerlo por SQL he estado mirando y creo que MySQL no admite la intercalación _AI. El problema que tengo está relacionado en el filtrado en el clientDataSet (o a lo sumo en el del ZQuery).

Por SQL aparentemente funciona correcto: en una sentencia tal como SELECT * FROM tabla WHERE nombre LIKE 'Jose'
me lista correctamente tanto José como Jose, es decir, el acento no es problema (el cotejamiento -collate- de MySQL lo tengo en latin1_spanish_ci).

En resumen, mi objetivo sería utilizar los filtros del clientDataSet sin tener que ejecutar explicitamente una sentencia SQL para cada letra que escriba en el TEdit (lo adecuado sería que el filtro lo hiciera solo, ¡para eso está!) pero mi único problema en ese momento es el de los acentos.

Si utilizo el evento OnFilterRecord del clientDataSet, tal como Accept := AnsiContainsText(cdsEditaCliente.Fieldbyname('Nombre').AsString , edClienteABuscar.Text);
igualmente tengo el problema con los acentos. Si utilizo este mismo evento del Zquery no funciona.

¿Alguien puede aportarme alguna idea?

d3nz1g
26-11-2015, 21:36:33
Saludos,

Se que este hilo tiene bastante tiempo sin actividad pero tope con el mismo problema y buscando un poco más encontré una posible solución:

Para filtrar un CDS (ClientDataSet) existen 2 posibilidades: usar la propiedad filter del CDS, o utilizar un evento personalizado para la propiedad OnFilterRecord, de manera que este sea el criterio que se utilice para evaluar los registros del CDS. Con esta última opción, al habilitar la propiedad filtro, se filtrarán aquellos registros que cumplan con las propiedades dadas.

Por ejemplo:

procedure TFormConsultaActividades.CDSFilterRecord(DataSet: TDataSet;var Accept: Boolean);
begin
Accept := Pos(AnsiUpperCase('ó'),AnsiUpperCase(ClientDataSet.FieldByName('DESCRIPCION').asString)) > 0;
end;

Con el código anterior, el filtro dejaría accesibles todos los registros que posean la letra o tildada:

Aplicacion
Aplicación
Hormiga
Colón
Restauración
Filtro
Armería

En el caso del requerimiento original que indicaba Josepo (que tome en cuenta tanto hileras tildadas como sin tilde) me parece que simplemente habría que ajustar el código del evento OnFilterRecord para que sustituya aquellos caracteres tildados en ambas partes antes de realizar la comparación de valores.

PD: Probado con Delphi 2010.

Saludos!