AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Problem mit Boolean bei MySQL und ZEOS
Thema durchsuchen
Ansicht
Themen-Optionen

Problem mit Boolean bei MySQL und ZEOS

Ein Thema von Angel4585 · begonnen am 19. Apr 2006 · letzter Beitrag vom 19. Apr 2006
Antwort Antwort
Seite 1 von 2  1 2      
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#1

Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 10:33
Datenbank: MySQL • Version: 5 • Zugriff über: 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
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 10:36
Versuchs mal mit .FieldByName(Feldname).Value := True; oder erzeuge ien Zugriffsfels als Booleanfeld in der IDE.
Markus Kinzler
  Mit Zitat antworten Zitat
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#3

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 10:40
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?
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 10:48
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?
Markus Kinzler
  Mit Zitat antworten Zitat
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#5

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 10:55
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.
Miniaturansicht angehängter Grafiken
mysqlboolean_821.jpg  
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 11:01
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?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Gollum
Gollum

Registriert seit: 14. Jan 2003
Ort: Boxberg
456 Beiträge
 
Delphi 10.1 Berlin Professional
 
#7

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 11:05
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.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#8

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 11:06
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.
Stephan B.
  Mit Zitat antworten Zitat
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#9

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 11:07
@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"
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#10

Re: Problem mit Boolean bei MySQL und ZEOS

  Alt 19. Apr 2006, 11:14
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
Stephan B.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:02 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz