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