AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TStringList Add aus SQLite

Ein Thema von cltom · begonnen am 16. Nov 2021 · letzter Beitrag vom 17. Nov 2021
Antwort Antwort
cltom

Registriert seit: 22. Sep 2005
221 Beiträge
 
Delphi 12 Athens
 
#1

TStringList Add aus SQLite

  Alt 16. Nov 2021, 16:00
Datenbank: SQLite • Version: 3.36 • Zugriff über: ZEOS
Hallo,

aus einer SQlite-DB soll ein Textfeld in eine StringList gelesen werden.

Sinngemäß also:

Delphi-Quellcode:
var
  MyStringList : TStringList;

begin
  MyStringList := TStringList.Create;

// (some SQL query)

  MyStringlist.Add(ZQuery.FieldByName('TextField').AsString);

end;
wenn man das so macht, kommt der Text, aber mit jedem Aufruf, wird der Inhalt des Feldes hinzugefügt. Klar, is ja "Add"

wenn man nun aber

Delphi-Quellcode:
  ...
  MyStringList.Clear;
  MyStringList.Add ...
hinzufügt, dann erscheint es so, als würde nur der erste Eintrag gelesen werden, alle folgenden Queries ändern dann den Inhalt von MyStringlist nicht mehr ... da erscheint immer nur der erste gelesene Eintrag.

Was übersehe ich da?
Danke!
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.490 Beiträge
 
Delphi 7 Professional
 
#2

AW: TStringList Add aus SQLite

  Alt 16. Nov 2021, 16:08
Nicht nur den aktuellen Satz der Query lesen, sondern alle?
Delphi-Quellcode:
var
  MyStringList : TStringList;
  fTextField : TField;
begin
  MyStringList := TStringList.Create;
// (some SQL query)
  fTextField := ZQuery.FindByName('TextField');
  ZQuery.First;
  while not ZQuery.EoF do begin
    MyStringlist.Add(fTextField.AsString);
    ZQuery.Next;
  end;
end;
  Mit Zitat antworten Zitat
cltom

Registriert seit: 22. Sep 2005
221 Beiträge
 
Delphi 12 Athens
 
#3

AW: TStringList Add aus SQLite

  Alt 16. Nov 2021, 22:16
Nicht nur den aktuellen Satz der Query lesen, sondern alle?
Delphi-Quellcode:
var
  MyStringList : TStringList;
  fTextField : TField;
begin
  MyStringList := TStringList.Create;
// (some SQL query)
  fTextField := ZQuery.FindByName('TextField');
  ZQuery.First;
  while not ZQuery.EoF do begin
    MyStringlist.Add(fTextField.AsString);
    ZQuery.Next;
  end;
end;
jetzt macht es Sinn! die Query ist falsch und in Kombination mit nur der ersten Zeile auslesen erklärt es das Verhalten, danke!
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#4

AW: TStringList Add aus SQLite

  Alt 17. Nov 2021, 06:16
Moin...
Zitat:
jetzt macht es Sinn!
noch nicht...

Frage wo gibst du die Liste frei?
2 Möglichkeiten:
1. die function mit Createxxx: List beginnen, damit man weiß, daß die Liste neu erzeugt wurde
2. die Liste in der aufrufenden procedure erzeugen und übergeben.

besser:
Delphi-Quellcode:
//Variante 2:
procedure Blubb(List: TStrings)
begin
// (some SQL query)
  ZQuery.Open;
  while not ZQuery.EoF do
  begin
    List.Add(ZQuery.FindByName('TextField').AsString);
    ZQuery.Next;
  end;
end;
  Mit Zitat antworten Zitat
cltom

Registriert seit: 22. Sep 2005
221 Beiträge
 
Delphi 12 Athens
 
#5

AW: TStringList Add aus SQLite

  Alt 17. Nov 2021, 11:05
Moin...
Zitat:
jetzt macht es Sinn!
noch nicht...

Frage wo gibst du die Liste frei?
2 Möglichkeiten:
1. die function mit Createxxx: List beginnen, damit man weiß, daß die Liste neu erzeugt wurde
2. die Liste in der aufrufenden procedure erzeugen und übergeben.

besser:
Delphi-Quellcode:
//Variante 2:
procedure Blubb(List: TStrings)
begin
// (some SQL query)
  ZQuery.Open;
  while not ZQuery.EoF do
  begin
    List.Add(ZQuery.FindByName('TextField').AsString);
    ZQuery.Next;
  end;
end;
Danke, dass Du Dir noch Gedanken dazu machst!

Du meinst, damit nicht mehrfach ein Create der gleichen StringList erzeugt wird?

Ok, da passt das Codeschnipsel nicht ganz. Das Create wird woanders aufgerufen. Tie TStringList ist innerhalb einer Klasse, in deren constructor ich gleich die StringList erzeuge. Ob das elegant so ist, steht auf einem anderen Blatt ...
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#6

AW: TStringList Add aus SQLite

  Alt 17. Nov 2021, 15:23
Hallöle...
Zitat:
Ob das elegant so ist, steht auf einem anderen Blatt
...ist schon in Ordnung.

Es lesen ja auch andere mit und übernehmen die Speicherlöcher aus dem Quelltext.
  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 18:42 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