Ver Mensaje Individual
  #4  
Antiguo 01-03-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Reputación: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Pues no, no es lo que quería decir.

Lo que quería decir es que AsBoolean, tanto en ZQuery.ParamByName(...).AsBoolean como en ZQuery.FieldByName(...).AsBoolean, debían traducir correctamente el tipo de datos.

Se supone que una de las ventajas de usar parámetros en las consultas es justamente la traducción de los tipos de datos. Así, al poner:

Código Delphi [-]
with Query do
begin
  SQL.Add( 'UPDATE la_tabla' );
  SQL.Add( '   SET respuesta = :resp'); 
  SQL.Add( '   WHERE clave = :clave');

  ParamByName('resp').AsBoolean := true;
  ParamByName('clave').AsString := 'RX-56';

  ExecSQL;
end;

la componente debería traducir true al valor correcto de 1 y RX-56 al valor entrecomillado "RX-56".

Sin embargo, esto no es así en ZEOS, según acabo de comprobar (al menos el paso de Boolean a TinyInt).

Peor aún, al tratar de leer un valor de una consulta SELECT con FieldByName('respuesta').AsBoolean me lanza una excepción.

En muchos aspectos las componentes ZEOS son muy eficiente pero son este tipo de detalles los que cada vez me desaniman más a usarlas y recomendarlas.

Las misma pruebas hechas con las componetes MyDac de CoreLab devuelven los resultados esperados. El valor true en ParamByName se convierte a 1 y el valor false a 0 y el valor del campo es correctamente devuelto con FieldByName().AsBoolean.

// Saludos
Responder Con Cita