AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Daten mit ID in eine ComboBox laden?
Thema durchsuchen
Ansicht
Themen-Optionen

Daten mit ID in eine ComboBox laden?

Ein Thema von AlexII · begonnen am 26. Okt 2012 · letzter Beitrag vom 26. Okt 2012
Antwort Antwort
Seite 1 von 2  1 2      
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#1

Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:35
Datenbank: SQLite • Version: 3 • Zugriff über: SQLite4Delphi Wrapper von Tim Anderson
Hallo,

ich hab hier ein folgendes Problem, wo ich Gedankenanstöße brauchen.
Also ich möchte aus einer DB Daten laden, in meinem Beispiel die Namen der Kunden. Das klappt auch soweit, nur wohin lade ich die IDs der Kunden? So ne Art wie .Data gibt's bei den ComboBoxen so wie ich sehe nicht. Was mache ich da am besten, ne virtuelle StringList oder so nehmen, oder gibt's da schönere Vorgehensweisen?

Danke!
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:37
Jede Komponente besitzt die .Tag Eigenschaft, die du hierfür verwenden kannst.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#3

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:39
  Combobox1.Items.AddObject(KundenName.asString,TObject(KundenID.asInteger));
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Benutzerbild von scrat1979
scrat1979

Registriert seit: 12. Jan 2007
Ort: Sulzbach a.d. Murr
1.029 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:40
Verwendet bei der combobox nicht .Add('') sondern .AddObject() und caste die ID (integer) als TObject
Michael Kübler
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#5

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:48
Ist mir ein bisschen zu kompliziert das mit TObject, aber ok, nun wie lese ich danach die ID wieder aus?
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
nuclearping

Registriert seit: 7. Jun 2008
708 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#6

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:49
Ist mir ein bisschen zu kompliziert das mit TObject, aber ok, nun wie lese ich danach die ID wieder aus?
ID := Integer(ComboBox1.Items.Objects[ComboBox1.ItemIndex]);
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#7

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 12:52
Ok, muss man überlegen was mir am besten passt, und wie kann man die Tags der einzelnen Zeilen auslesen?
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Popov
(Gast)

n/a Beiträge
 
#8

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 17:17
Ist mir ein bisschen zu kompliziert das mit TObject
Das glaub ich dir, das täuscht letztendlich aber. Wenn man das aber paar mal gemacht, fragt man sich wieso man es früher immer anders gemacht hat. Kleines Beispiel:

Delphi-Quellcode:
type
  TInfo = class //Beispiel-Klasse
    DT: TDateTime;
  end;

procedure ListBoxItemDelete(ListBox: TListBox; Index: Integer);
begin
  if (Index < 0) or (Index > ListBox.Items.Count - 1) then Exit;
  ListBox.Items.Objects[Index].Free; //Items mit Objekte löschen
  ListBox.Items.Delete(Index);
end;
 
procedure TForm1.Button1Click(Sender: TObject);
var
  Info: TInfo;
  p: Integer;
begin
  with ListBox1 do
  begin
    Info := TInfo.Create; //Beispiel-Objekt Erstellen
    Info.DT := Now;

    p := Items.AddObject('Datum und Zeit', Info); //Zuweisen

    if p > -1 then
      ShowMessage(Format('Aktuelle Zeit im Item %d als Objekt gespeichert.', [p]));
  end;
end;
 
procedure TForm1.ListBox1Click(Sender: TObject);
var
  DT: TDateTime;
  Info: TInfo;
begin
  with ListBox1 do
  begin
    if Count = 0 then Exit;
    if ItemIndex = -1 then Exit;
 
    Info := TInfo(Items.Objects[ItemIndex]); //Auslesen
    DT := Info.DT;

    ShowMessage('Im Objekt gespeicherte Zeit: ' + TimeToStr(DT));
  end;
end;

procedure TForm1.FormDestroy(Sender: TObject);
var
  i: Integer;
begin
  //Objekte müssen freigegeben werden
  for i := Items.Count - 1 downto 0 do
    ListBoxItemDelete(ListBox1, i);
end;
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 17:33
Also ich halte ja wirklich nichts davon irgendwelche Informationen an ein Control zu ketten, welches für die Visualisierung zuständig ist, die für die Visualisierung nicht benötigt werden. Die haben da nichts zu suchen.

Siehe dazu auch meinen Beitrag http://www.delphipraxis.net/171223-d...-einer-id.html
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#10

AW: Daten mit ID in eine ComboBox laden?

  Alt 26. Okt 2012, 15:21
ich hab hier ein folgendes Problem, wo ich Gedankenanstöße brauchen.
Also ich möchte aus einer DB Daten laden, in meinem Beispiel die Namen der Kunden.
Und was sricht dagegen das genauso zu tun?
vereinfacht sollte das so ablaufen:
Code:
Combobox1.Items:='select distinct name from kunden';

Erglist.strings.add(select namedaten from kunden where name=:combobox.selecteddata);
if erglist.count>1 then Namensentscheidung
Zum einen ist es nicht ungewöhnlich, daß Namen doppelt auftauchen, dann muß man Vornamen,Adresse etc. zur Unterscheidung dazu packen, und der Wähler muß diese natürlich auch sehen.

Hast Du sagen wir 10 Namen und 12 Einträge ist klar mindestens ein Name ist zweimal vorhanden.
Wenn während der Auswah ein 13 Eintrag erstellt wird und die Anzahl der unterschiedlichen Namen sich nicht ändert, oder es gibt einen neuen Namen...
Wie willst Du den dann ereichen, wenn Du mit dem Pärchen Name/ID operieren willst?

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 08:06 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz