AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString
Thema durchsuchen
Ansicht
Themen-Optionen

Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

Ein Thema von Angel4585 · begonnen am 7. Mär 2013 · letzter Beitrag vom 8. Mär 2013
Antwort Antwort
Angel4585

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

Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 12:17
Datenbank: MySQL • Version: 5.0.51b • Zugriff über: ZEOS 7.0.3
Guten Tag!

Icc habe die gleiche Fehlermeldung wie in diesem Thread beschrieben: http://www.delphipraxis.net/47101-mi...zugreifen.html

Da ich vermutlich mit einer neueren Version von ZEOS arbeite, frage ich mich woran das jetzt genau liegt, da der dort angegebene Link zur Fehlermeldung nicht mehr funktioniert.

Ich habe gerade versucht älteres Programm welches mit einer alten Verison von ZEOS und Delphi 2005 compiliert wurde unter Delphi 2010 mit ZEOS 7.0.3 zum Laufen zu bringen. Und stoße auf die Meldung:

tqServiceOptions: Unterschiedliche Typen für Feld 'Betreff'; erwartet: String, gefunden: WideString

tqServiceOptions ist der name der TZQuery
Betreff ist ein TStringField mit 80 Zeichen.

In der Datenbank ist Betreff ein VarChar mit 80 Zeichen.
Die Datenbanktabelle ist InnoDB.

Der Fehler selbst kommt beim Open-Befehl.
Der SQL-Befehl ist schlicht "select * from Tabellenname".
Hat jemand eine Idee woran das liegen könnte?
Hier noch mehr Details zur Meldung:

Zitat:
[5067E817]{dbrtl140.bpl} DB.DatabaseError (Line 2884, "DB.pas" + 2) + $36
[5067E8A1]{dbrtl140.bpl} DB.DatabaseErrorFmt (Line 2891, "DB.pas" + 1) + $15
[149EB34D]{ZComponent140.bpl} Zabstractrodataset.TZAbstractRODataset.CheckFieldC ompatibility + $99
[506917E6]{dbrtl140.bpl} DB.DoBindFields (Line 11629, "DB.pas" + 26) + $17
[506918E1]{dbrtl140.bpl} DB.TDataSet.BindFields (Line 11654, "DB.pas" + 4) + $7
[149E8AB6]{ZComponent140.bpl} Zabstractrodataset.TZAbstractRODataset.InternalOpe n + $256
[50690D05]{dbrtl140.bpl} DB.TDataSet.DoInternalOpen (Line 11328, "DB.pas" + 2) + $4
[50690DBE]{dbrtl140.bpl} DB.TDataSet.OpenCursor (Line 11357, "DB.pas" + 4) + $2
[50690C79]{dbrtl140.bpl} DB.TDataSet.SetActive (Line 11310, "DB.pas" + 12) + $7
[500516EE]{rtl140.bpl } TypInfo.SetOrdProp (Line 1723, "TypInfo.pas" + 27) + $0
[20DA5FF2]{designide140.bpl} DesignEditors.TPropertyEditor.SetOrdValue (Line 841, "DesignEditors.pas" + 2) + $E
[20DEB0FD]{designide140.bpl} VCLEditors.TBooleanProperty.MouseUp (Line 1838, "VCLEditors.pas" + 5) + $10
[20EBFF05]{vclide140.bpl} PropBox.TCustomPropListBox.ItemMouseUp (Line 1625, "propbox.pas" + 16) + $1B
[20EC00FB]{vclide140.bpl} PropBox.TCustomPropListBox.MouseUp (Line 1690, "propbox.pas" + 1) + $D
[50296810]{vcl140.bpl } Controls.TControl.DoMouseUp (Line 7306, "Controls.pas" + 2) + $28
[5029688C]{vcl140.bpl } Controls.TControl.WMLButtonUp (Line 7319, "Controls.pas" + 9) + $6
[20EC5740]{vclide140.bpl} IDEInspListBox.TInspListBox.WMLButtonUp (Line 1615, "IDEInspListBox.pas" + 3) + $4
[50295E70]{vcl140.bpl } Controls.TControl.WndProc (Line 7062, "Controls.pas" + 91) + $6
[50299FCB]{vcl140.bpl } Controls.TWinControl.IsControlMouseMsg (Line 9596, "Controls.pas" + 1) + $9
[5029098A]{vcl140.bpl } Controls.FindControl (Line 3377, "Controls.pas" + 6) + $9
[5029A738]{vcl140.bpl } Controls.TWinControl.WndProc (Line 9819, "Controls.pas" + 144) + $6
[501F06D4]{vcl140.bpl } StdCtrls.TCustomListBox.WndProc (Line 6117, "StdCtrls.pas" + 37) + $4
[50299DD8]{vcl140.bpl } Controls.TWinControl.MainWndProc (Line 9540, "Controls.pas" + 3) + $6
[50076408]{rtl140.bpl } Classes.StdWndProc (Line 13015, "Classes.pas" + 8) + $0
[502C9921]{vcl140.bpl } Forms.TApplication.StopHintTimer (Line 10491, "Forms.pas" + 3) + $6
[502C8775]{vcl140.bpl } Forms.TApplication.ProcessMessage (Line 9760, "Forms.pas" + 30) + $1
[502C87BA]{vcl140.bpl } Forms.TApplication.HandleMessage (Line 9790, "Forms.pas" + 1) + $4
[502C8AE5]{vcl140.bpl } Forms.TApplication.Run (Line 9927, "Forms.pas" + 26) + $3
[004369AE]{bds.exe } bds.bds (Line 200, "" + 8) + $FFFB
Wenn ich die betroffenen Felder (alle String-Felder) neu mache als TWideStringField anstatt TStringField, dann klappt es.
Aber das möchte ich natürlich nicht für die ganzen Felder. Wo/was muss ich ändern, damit ich die Felder der Tables und Queries nicht ändern muss?
Martin Weber
Ich bin ein Rüsselmops

Geändert von Angel4585 ( 7. Mär 2013 um 12:30 Uhr)
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#2

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 12:49
Ich habe gerade versucht älteres Programm welches mit einer alten Verison von ZEOS und Delphi 2005 compiliert wurde unter Delphi 2010 mit ZEOS 7.0.3 zum Laufen zu bringen. Und stoße auf die Meldung: tqServiceOptions: Unterschiedliche Typen für Feld 'Betreff'; erwartet: String, gefunden: WideString
Du mußt einfach nur überall dort, wo String erwartet, aber WideString steht, diesen durch String ersetzen. Seit Delphi 2009 sind Strings praktisch Widestrings und Unicode-fähig. Vorher waren Strings auf 255 Zeichen begrenzt und AnsiStrings. WideStrings waren ebenfalls AnsiStrings, jedoch ohne Begrenzung. Daß hier ein Kompatibilitätsproblem auftritt, ist zwangsläufig.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.195 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 12:54
Vorher waren Strings auf 255 Zeichen begrenzt
Falsch! Strings ware nur unter Delphi 1 nur 255 Zeichen lang. Ab D2 konnten sie theoretisch 4 Mrd. Einträge lang sein.

WideStrings waren ebenfalls AnsiStrings, jedoch ohne Begrenzung.
Falsch! Widestring waren und sind Widestrings. Wären sie Ansi-Strings hätte man mit COM/ActiveX so die Probleme.
Windows Vista - Eine neue Erfahrung in Fehlern.
  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
 
#4

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 12:54
Der Fehler tritt bereits im Designer auf, wenn ich die TZQuery auf Active schalte.
Da kann ich nirgends String nach WideString oder andersrum ändern.

Ich könnte bei der TZConnection von UTF16 auf UTF8 wechseln(falls das überhaupt was bringt), aber es springt immer wieder automatisch zurück.

Sehr rätselhaft das Ganze
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 12:55
AnsiStrings waren nicht begrenzt und WideStrings war ein unmanaged Typ ( Delphi hat sich nicht direkt um die Speicherverwaltung und Inhalt gekümmert) Inhalt war interpretationssache ( z.B. ANSI, UTF8 oder UTF16 bei WinAPI-Aufrufen)
Markus Kinzler
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#6

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 7. Mär 2013, 13:07
Vorher waren Strings auf 255 Zeichen begrenzt
Falsch! Strings ware nur unter Delphi 1 nur 255 Zeichen lang. Ab D2 konnten sie theoretisch 4 Mrd. Einträge lang sein.

WideStrings waren ebenfalls AnsiStrings, jedoch ohne Begrenzung.
Falsch! Widestring waren und sind Widestrings. Wären sie Ansi-Strings hätte man mit COM/ActiveX so die Probleme.
Danke! Wieder was dazugelernt
  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
 
#7

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 8. Mär 2013, 08:29
Schade das mir niemand direkt weiterhelfen kann

Dann werd ich das wohl doch so lösen müssen, dass ich die ganzen Felder in TWideStringField's umändere.
Oder eben komplett aus den Tables/Queries rausnehmen.

Ich versteht einfach nicht wie Zeos entscheidet, dass das jetzt ein TWideStringField sein muss.
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 8. Mär 2013, 08:35
Unicode-Feldtyp (z.B. UTF8) 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
 
#9

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 8. Mär 2013, 08:52
Bei Kollation ist latin1_swedish_ci angegeben

Aber ich mein.. selbst wenn keine Verbindung hergestellt wird, wird automatisch ein TWideStringField vorgeschlagen.

Bei der TZConnection ist bei ControlsCodePage cCP_UTF16 eingestellt, was sich auch nicht auf cCP_UTF8 umstellen lässt, die Einstellung spring immer wieder automatisch zurück auf cCP_UTF16.
Genau wie die Einstellung UFT8StringsAsWideFields die immer auf true springt auch wenn ich false auswähle.

Hab sogar schon versucht direkt in der dfm rumzupfuschen aber selbst damit springen die Werte nach einer Änderung wieder zurück.
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
EgonHugeist

Registriert seit: 17. Sep 2011
187 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#10

AW: Zeos:Unterschiedliche Typen für Feld;erwartet: String, gefunden: WideString

  Alt 8. Mär 2013, 09:04
@Angel4585

Stelle TZConnection.ControlsCodePage = cCP_GETACP ein und du brauchst nichts beim Upgrade auf Z7 ändern.

Ich habe diese Option reingefummelt. Sie ist eigentlich interessanter für die Ansi-Pascal-Compiler. Es giebt Controls wie die TNT Controls, welche auf Wide-Fields zugreifen können. Andere brauchen UTF8-1Byte Strings. Die Ansi-Delphi standart Contrls, jedoch greifen immer auf String-Fields zu. Zeos ist in der Lage jede CodePage von der Client-Seite auf Wide-Fields zu Mappen. Dies gilt selbstverständlich auch für String-Fields. Dafür diese Option. Unter den Unicode IDE's hab ich die ControlsCodePage cCP_UTF8 unterbunden, da es mit einigen OS-Codepages wie GB1080 simplified chinese, Probleme gab. Da scheint irgend etwas mit dem AnsiToWide und umgedreht im argen zu liegen...

UTF8AsWideString Fields ist out of use und wird mit Zeos7.1 entfernt.

Gruß Michael
  Mit Zitat antworten Zitat
Antwort Antwort


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:34 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