Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Problem mit Boolean bei MySQL und ZEOS (https://www.delphipraxis.net/67738-problem-mit-boolean-bei-mysql-und-zeos.html)

Angel4585 19. Apr 2006 10:33

Datenbank: MySQL • Version: 5 • Zugriff über: ZEOS

Problem mit Boolean bei MySQL und ZEOS
 
Hallo zusammen,

ich hab gerade das Problem, das ich ein Datenfeld vom Typ "BOOLEAN" in meiner MySQL Tabelle habe und eine Checkbox mit diesem Feld verbunden habe.

Wenn ich jetzt dieses Feld "True" oder "False" setzen und das Speichern will kommt die Meldung "Wahr ist kein gültiger Integerwert".

Wenn ich das manuell mit AsInteger mache würde es gehen:

Delphi-Quellcode:
FieldByName(Feldname).AsBoolean:=True;//funktioniert nicht
FieldByName(Feldname).AsInteger:=1;//funktioniert
weis jemand als was für einen Typ ich das Feld machen muss, damit es auch Werte wie "True" oder "False" akzeptiert?

MfG :angel:

mkinzler 19. Apr 2006 10:36

Re: Problem mit Boolean bei MySQL und ZEOS
 
Versuchs mal mit
Delphi-Quellcode:
.FieldByName(Feldname).Value := True;
oder erzeuge ien Zugriffsfels als Booleanfeld in der IDE.

Angel4585 19. Apr 2006 10:40

Re: Problem mit Boolean bei MySQL und ZEOS
 
das mit Value funktioniert nicht, da wird garnichts reingeschrieben.

Es muss doch ein DatenTyp geben, den ich bei erzeugen der Tabelle angebe wo ich dann aich Tru und False reinschreibe oder nicht?

mkinzler 19. Apr 2006 10:48

Re: Problem mit Boolean bei MySQL und ZEOS
 
TFields sin Varinaten. Mit .Value setzt du den Wert mit erkannten oder explizit gesetzten Wert.
Zitat:

...da wird garnichts reingeschrieben.
Steht dann 0 in der Datenbank?

Angel4585 19. Apr 2006 10:55

Re: Problem mit Boolean bei MySQL und ZEOS
 
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:

Zitat von mkinzler
TFields sin Varinaten. Mit .Value setzt du den Wert mit erkannten oder explizit gesetzten Wert.
Zitat:

...da wird garnichts reingeschrieben.
Steht dann 0 in der Datenbank?

ne es wird "-1" reingeschrieben.. siehe screenshot.

mkinzler 19. Apr 2006 11:01

Re: Problem mit Boolean bei MySQL und ZEOS
 
Sehr komisch, -1 ist ja kein gültiger Wert für ein Booleanfeld.
Der Zugriff geschieht aber wieder mit ZEOS. Erzeuge mal zum Test ein Zugriffsfeld als Booleanfeld und lass dir dann mal den Wert anzeigen. Was zeigt ein MysqlAdmin-Programm als Wert?

Gollum 19. Apr 2006 11:05

Re: Problem mit Boolean bei MySQL und ZEOS
 
Hallo,

laut MySQL-Hilfe ist der Datentyp Boolean ein Synonym für TinyInt.
Dies bedeutet, 0 entspricht False und alles ungleich 0 entspricht True.

Eine SQL-Konforme-Variante des Datentypes ist für spätere Versionen vorgesehen.

Sharky 19. Apr 2006 11:06

Re: Problem mit Boolean bei MySQL und ZEOS
 
Zitat:

Zitat von mkinzler
Sehr komisch, -1 ist ja kein gültiger Wert für ein Booleanfeld. ...

By mySQL kann man das aber machen (leider). Ein Boolen wird ja bei mySQL immer als TinyInt(1) gespeichert. Und per definition ist 0 = False und <> 0 ist True.

Angel4585 19. Apr 2006 11:07

Re: Problem mit Boolean bei MySQL und ZEOS
 
@Gollum&Sharky:

wie kann ich dann mit einer DBCheckbox einen Wert setzen?
Genau da kommt nämlich die Meldung von wegen "True ist kein gültiger Integer-Wert" :wall:

Sharky 19. Apr 2006 11:14

Re: Problem mit Boolean bei MySQL und ZEOS
 
Zitat:

Zitat von Angel4585
...wie kann ich dann mit einer DBCheckbox einen Wert setzen? ...

Hai Angel,

setze im OI bei der DBCheckBox
Code:
ValueChecked := 1
ValueUnchecked := 0
und erfreue Dich deiner CheckBox ;-)

Gollum 19. Apr 2006 11:14

Re: Problem mit Boolean bei MySQL und ZEOS
 
Hallo,

über die Ereignisse OnGetText und OnSetText der Eigenschaft Fields der DBCheckBox.
Mit diesen Ereignissen kannst Du selber bestimmen, was mit den aus der DB gelesen Werten geschieht.

Näheres dazu siehe

Angel4585 19. Apr 2006 11:17

Re: Problem mit Boolean bei MySQL und ZEOS
 
THX Sharky, genau das was ich gebrauch hab :thumb:

uwewo 19. Apr 2006 11:31

Re: Problem mit Boolean bei MySQL und ZEOS
 
Hallo,

den FeldTyp den Du brauchst ist "Enum", dieser Typ kann verschiedene Werte annehmen.
z.Bsp: 'Ja','Nein' 'Wahr', 'Falsch' usw.

SQL-Code:
add column `BooleanFeld` enum ('Wahr','Falsch') DEFAULT 'Wahr' NOT NULL
Damit funktioniert es auf jedenfall

Uwe


Alle Zeitangaben in WEZ +1. Es ist jetzt 17:56 Uhr.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz