Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   unerklärliche Speicheradresszuweisung (https://www.delphipraxis.net/192559-unerklaerliche-speicheradresszuweisung.html)

EdAdvokat 1. Mai 2017 11:30

Datenbank: SQLite-3 • Version: 3 • Zugriff über: ZeosLib

unerklärliche Speicheradresszuweisung
 
ich will eine sqlite-Datentabelle in mein Programm laden. Es handelt sich um eine einfache Adressverwaltung(Name,Vorname,Strasse, Nr ...). Das klappt insoweit, dass ich die Datensätze mit folgenden Werten angezeigt bekomme: Name richtig, statt Vorname die Hausnummer, Strasse richtig und das Feld Hausnummer bleibt leer.
Kommentiere ich die Quelltextzeile mit dem laden der Nr aus, erhalte ich den Datensatz exakt mit Vorname, Name, Strasse jedoch ohne Nr für Hausnummer.
Bei einer genaueren Untersuchung der nichtauskommentierten Zeile stelle ich fest, dass Name und Vorname jeweils eine Speicheradresse erhalten und zunächst auch im Debuggingverlauf der exakte Name und Vorname erscheinen.
Wird jedoch das Feld Nr geladen wird die Speicheradresse von Vorname so verändert, dass eine Speicheradresse von Nr zugewiesen wird und Helga heißt plötzlich 45, wie eigentlich die Hausnummer lauten soll. Doch die Speicheradresse von Nr bleibt nil. Habe zwischenzeitlich auch eine neue Datenbanktabelle erstellt mit dem gleichen Ergebnis.
Ich kann mir diese eigenartige Speicherzuweisung einfach nicht erklären.

Olli73 1. Mai 2017 11:36

AW: unerklärliche Speicheradresszuweisung
 
Etwas Code wäre vielleicht hilfreich.

EdAdvokat 1. Mai 2017 11:46

AW: unerklärliche Speicheradresszuweisung
 
bei Programmstart wird die folgende Methode ausgeführt:
Delphi-Quellcode:
procedure TAdressbuch.loadFromDB(con: TZConnection);
var
  qMain: TZQuery;
  Adressen: TAdressen;
begin
  qMain:=TZQuery.Create(nil);
  try
    self.AdressList.Clear;
    qMain.connection:=con;
    qMain.sql.Text:= 'SELECT * FROM KONTAKTE1';
    qMain.active:=true;
    while not qMain.eof do
    begin
      Adressen:=TAdressen.create;
      Adressen.ID:=qMain.FieldByName('ID').AsInteger;
      Adressen.Name:=qMain.FieldByName('Name').AsString;
      Adressen.Vorname:=qMain.FieldByName('Vorname').AsString;
      Adressen.Geb:=qMain.FieldByName('Geb').AsString;
      Adressen.Strasse:=qMain.FieldByName('Strasse').AsString;
      Adressen.Nr:=qMain.FieldByName('Nr').AsString; //<----hier entscheidene Zeile!
      Adressen.PLZ:=qMain.FieldByName('PLZ').AsString;
      Adressen.Ort:=qMain.FieldByName('Ort').AsString;
      Adressen.Tel:=qMain.FieldByName('Tel').AsString;
      Adressen.email:=qMain.FieldByName('email').AsString;
      Adressen.Bemerkung:=qMain.FieldByName('Bemerkung').AsString;
      self.AdressList.Add(Adressen);
      qMain.Next;
    end;
      qMain.Active:=false;
  finally
    qMain.Free
  end;

end;

Olli73 1. Mai 2017 11:51

AW: unerklärliche Speicheradresszuweisung
 
Wie ist den TAdressen deklariert. Vielleicht ist dort ein Setter fehlerhaft oder so.

EdAdvokat 1. Mai 2017 12:15

AW: unerklärliche Speicheradresszuweisung
 
Danke für den Hinweis. Ja tatsächlich es war ein falscher Setter!:oops:


Alle Zeitangaben in WEZ +1. Es ist jetzt 04:40 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