Hallo,
in einer Tabelle habe ich ein Feld, welches ich als Wert einer Combobox zuweise.
Das passiert, weil vorhandene Werte bei Neueingaben zur Verfügung stehen sollen.
Nun dauert das ganze sehr lange, weil ich alle Einträge durchlaufe und zu einer Liste hinzufüge, die ich dann der jeweiligen Combobox zuweise.
Das ist mein Code dazu:
Delphi-Quellcode:
procedure TForm3.InitComboBox(Table_toInit: TABSTable);
var
X: Integer;
Dummy_String: string;
Dummy_SL1, Dummy_SL2: TStringList;
Dummy_SL_Regal, Dummy_SL_Fach: TStringList;
begin
{ Ersten Datensatz anwählen }
Form_Bibo2.ABSTable1.First;
{ Listen initialisieren }
Dummy_SL1 := TStringList.Create;
Dummy_SL1.Sorted := True;
Dummy_SL1.Duplicates := dupIgnore;
Dummy_SL2 := TStringList.Create;
Dummy_SL2.Sorted := True;
Dummy_SL2.Duplicates := dupIgnore;
Dummy_SL_Regal := TStringList.Create;
Dummy_SL_Regal.Sorted := True;
Dummy_SL_Regal.Duplicates := dupIgnore;
Dummy_SL_Fach := TStringList.Create;
Dummy_SL_Fach.Sorted := True;
Dummy_SL_Fach.Duplicates := dupIgnore;
for X := low(Const_Autors) to high(Const_Autors) do
Dummy_SL1.Add(Const_Autors[X]);
for X := low(Const_Publishers) to high(Const_Publishers) do
Dummy_SL2.Add(Const_Publishers[X][1]);
{ Solange nicht das Tabellenende erreicht ist mache.. }
while not Table_toInit.Eof do
begin
{ Spalte einlesen Autor }
Dummy_String := Trim(Table_toInit.FieldByName(Table_Bibo2.Labels_DB[1]).AsString);
{ Länge prüfen }
if Length(Dummy_String) > 0 then
begin
{ Zur Liste hinzufügen }
Dummy_SL1.Add(Dummy_String);
end;
{ Spalte einlesen Publisher }
Dummy_String := Trim(Table_toInit.FieldByName(Table_Bibo2.Labels_DB[5]).AsString);
{ Länge prüfen }
if Length(Dummy_String) > 0 then
begin
{ Zur Liste hinzufügen }
Dummy_SL2.Add(Dummy_String);
{ Breite des Eintrages an die ComBobox weitergeben }
end;
{ Spalte einlesen Regal }
Dummy_String := Trim(Table_toInit.FieldByName(Table_Bibo2.Labels_DB[10]).AsString);
{ Länge prüfen }
if Length(Dummy_String) > 0 then
begin
{ Zur Liste hinzufügen }
Dummy_SL_Regal.Add(Dummy_String);
{ Breite des Eintrages an die ComBobox weitergeben }
end;
{ Spalte einlesen Fach }
Dummy_String := Trim(Table_toInit.FieldByName(Table_Bibo2.Labels_DB[11]).AsString);
{ Länge prüfen }
if Length(Dummy_String) > 0 then
begin
{ Zur Liste hinzufügen }
Dummy_SL_Fach.Add(Dummy_String);
{ Breite des Eintrages an die ComBobox weitergeben }
end;
{ Nächsten Datensatz anwählen }
Table_toInit.Next;
end;
{ .. und zurück zum ersten Datensatz }
Table_toInit.First;
{ ComboBox-Inhalte nun zuweisen }
ComboBox_AddBook_Author.Items.Assign(Dummy_SL1);
ComboBox_AddBook_Publisher.Items.Assign(Dummy_SL2);
ComboBox_AddBook_Regal.Items.Assign(Dummy_SL_Regal);
ComboBox_AddBook_Fach.Items.Assign(Dummy_SL_Fach);
{ Listen aus dem Speicher entfernen }
Dummy_SL1.Free;
Dummy_SL2.Free;
Dummy_SL_Regal.Free;
Dummy_SL_Fach.Free;
end;
Habt ihr eine Idee, wie ich die ganze Sache beschleunigen kann und wenn, geht das per
SQL Befehl?
LG Mathias