Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 01-03-2005
Avatar de salvica
salvica salvica is offline
Miembro
 
Registrado: mar 2004
Ubicación: Albacete (España) ... En un lugar de la Mancha ...
Posts: 304
Poder: 21
salvica Va por buen camino
Campos "boolean" en MySql

¿Podeis indicarme como puedo aplicar valores lógicos de Delphy en MySql?

He probado con "BOOL" (que según he leido por aquí es un sinónimo de TyniInt(1) ), con CHAR(1), con ENUM("Y", "N") y de todas las formas siempre acabo creando una rutina de transformación a la hora de leer/grabar los datos

MySql me dá la propiedad "AsBoolean" cuando efectúo un "FieldByName" pero no sé como crear la tabla para que admita campos lógicos

Gracias anticipadas
Responder Con Cita
  #2  
Antiguo 01-03-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
No hay campos lógicos en MySql. Tal como has visto, BOOL es un sinónimo de TinyInt(1). Pero en principio, con el dataset que uses para conectar con MySql puedes leer y escribir valores al campo precisamente con AsBoolean.

// Saludos
Responder Con Cita
  #3  
Antiguo 01-03-2005
Avatar de salvica
salvica salvica is offline
Miembro
 
Registrado: mar 2004
Ubicación: Albacete (España) ... En un lugar de la Mancha ...
Posts: 304
Poder: 21
salvica Va por buen camino
Ante todo gracias por responder.

Perdona pero se me fué el "dedo" al la hora de escribir la preguna

Cita:
MySql me dá la propiedad "AsBoolean" cuando efectúo un "FieldByName" pero no sé como crear la tabla para que admita campos lógicos

debería haber puesto
La Query de Zeos para MySql me dá la propiedad "AsBoolean" cuando efectúo un "FieldByName" pero no sé como crear la tabla para que admita campos lógicos
Por tu respuesta deduzco que debo seguir con las funciones
Código Delphi [-]
  function  tyniIntToBoolean( expresion:integer ):boolean
  begin
    Result := (expresion=1);
  end;
  
  function  booleanToTyniInt( expresion:boolean ):string;
  begin
    if expresion
       then Result := '1'
       else Result := '0';
  end;
y luego en el Form:
Código Delphi [-]
    with Query do begin
       SQL.Add( 'UPDATE la_tabla' );
       SQL.Add( '   SET respuesta = ' + booleanToTyniInt( xRespuesta ) );
       SQL.Add( ' WHERE clave = "' + strCLAVE + '" ) ' );
    end;
Responder Con Cita
  #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
Poder: 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
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 01:55:48.


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