AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken unerklärliche Speicheradresszuweisung
Thema durchsuchen
Ansicht
Themen-Optionen

unerklärliche Speicheradresszuweisung

Ein Thema von EdAdvokat · begonnen am 1. Mai 2017 · letzter Beitrag vom 1. Mai 2017
Antwort Antwort
EdAdvokat

Registriert seit: 1. Mai 2016
Ort: Berlin
414 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#1

unerklärliche Speicheradresszuweisung

  Alt 1. Mai 2017, 11:30
Datenbank: SQLite-3 • Version: 3 • Zugriff über: ZeosLib
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.
Norbert
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
662 Beiträge
 
#2

AW: unerklärliche Speicheradresszuweisung

  Alt 1. Mai 2017, 11:36
Etwas Code wäre vielleicht hilfreich.
  Mit Zitat antworten Zitat
EdAdvokat

Registriert seit: 1. Mai 2016
Ort: Berlin
414 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

AW: unerklärliche Speicheradresszuweisung

  Alt 1. Mai 2017, 11:46
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;
Norbert
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
662 Beiträge
 
#4

AW: unerklärliche Speicheradresszuweisung

  Alt 1. Mai 2017, 11:51
Wie ist den TAdressen deklariert. Vielleicht ist dort ein Setter fehlerhaft oder so.
  Mit Zitat antworten Zitat
EdAdvokat

Registriert seit: 1. Mai 2016
Ort: Berlin
414 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#5

AW: unerklärliche Speicheradresszuweisung

  Alt 1. Mai 2017, 12:15
Danke für den Hinweis. Ja tatsächlich es war ein falscher Setter!
Norbert
  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 21:58 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