![]() |
Datenbank: Access • Version: 2000 • Zugriff über: ADO
Suche Funktion die mir Primärindex zurück gibt
Hallo,
gibt es in Delphi ein Funktion, die mir den Primärindex eines Datensatzes zurückgibt? Ich erkläre am besten nochmal wofür ich das brauche. Ich habe auf meinem Kunden Formular eine ComboBox. Diese ComboBox fülle ich mit Daten aus meiner Tabelle Anreden. Um die dritte Normalform nicht zu verletzen, möchte ich nur den Index des Datensatzes in meiner Tabelle Kunden speichern, der in der ComboBox ausgewählt wurde. Früher habe ich es mit Locate gemacht. Diese Variante des suchens ist mir aber zu langsam. Ich suche etwas schnelleres, da ich das nicht nur bei den Anreden mache. Sondern auch noch bei den Titeln, Namenszusätzen, u.s.w. Vom Prinzip her brauche ich eine Funktion, der ich Tabellenname, Suchfeld und Rückgabefeld übergebe. Wahrscheinlich wird es sowas standardmäßig in Delphi 7 nicht geben. Deshalb muß ich mir wohl selber einen Kopf machen. Ich habe schon mal angefangen:
Delphi-Quellcode:
function findindex(Table : TADOTable; Search : String; Return : String) : Integer;
begin end; |
Re: Suche Funktion die mir Primärindex zurück gibt
Wie wäre es mit Lookup. Ob ein Index verwendet wird, entscheided ADO bzw. der Provider. Falls das zu langsam ist, arbeite mit 'SELECT'. Du bastelst Dir dann deine Abfrage on-the-fly selbst zusammen und schickst sie zur DB.
|
Re: Suche Funktion die mir Primärindex zurück gibt
Zitat:
ich "missbrauche" in solch einem Fall gerne die ![]() Hier einmal ein Beispiel:
Delphi-Quellcode:
Dadurch habe ich die id immer mit einer "Zeile" der Combobox (oder allem anderen was TStrings ist).
procedure TDemoForm.FormCreate(Sender: TObject);
var anrede: string; id: Cardinal; begin with ADOQuery1 do begin Close; SQL.Text := 'SELECT id, anrede FROM anreden'; Open; while not (eof) do begin id := FieldByName('id').AsInteger; anrede := FieldByName('anrede').AsString; cb_anreden.Items.AddObject(anrede, TObject(id)); // Die id wird auf TObject gecastet Next; end; end; end; procedure TDemoForm.btn_testClick(Sender: TObject); var id: Cardinal; begin id := Cardinal(cb_anreden.Items.Objects[cb_anreden.ItemIndex]); // Hier wird wieder auf Cardinal gecastet. ShowMessageFmt('Die aktuelle Auswahl hat die ID %d', [id]); end; |
Re: Suche Funktion die mir Primärindex zurück gibt
wie wäre es denn mit der Verwendung von LookUpCombo?
Imho die sinnvollste Möglichkeit. Gruß onlinekater |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:46 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