AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Abfrage mittels SQL - Ergebnis?
Thema durchsuchen
Ansicht
Themen-Optionen

Abfrage mittels SQL - Ergebnis?

Ein Thema von NoGAD · begonnen am 21. Apr 2022 · letzter Beitrag vom 22. Apr 2022
Antwort Antwort
Benutzerbild von NoGAD
NoGAD

Registriert seit: 31. Jan 2006
Ort: Weimar
345 Beiträge
 
Delphi 10.4 Sydney
 
#1

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 21:29
Bisher hatte ich immer mit ABSTable gearbeitet.
Und wie hast du es da gemacht?
Mittels ABSTable1.Locate('KUNDEN', 'SUCHSTRING', []);

Dann hatte ich den Datensatz, den ich benötigte.

LG
Mathias
Ich vergesse einfach zu viel.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.663 Beiträge
 
Delphi 12 Athens
 
#2

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 21:54
Mittels ABSTable1.Locate('KUNDEN', 'SUCHSTRING', []);

Dann hatte ich den Datensatz, den ich benötigte.
Ich vermute mal, KUNDEN steht für KUNDENNUMMER und SUCHSTRING für die höchste Kundennummer? Dann musst du aber diese ja auch irgendwie ermitteln, oder?

Aber egal. Wenn die Query SELECT * FROM dbKUNDEN ist, dann funktioniert das Locate dort auch so. Bei SELECT * FROM dbKUNDEN ORDER BY KUNDENNUMMER kommen die Daten sogar sortiert an. Dann wäre ein ABSQuery1.Last ausreichend um den Datensatz mit der höchsten Kundennummer auszuwählen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von NoGAD
NoGAD

Registriert seit: 31. Jan 2006
Ort: Weimar
345 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 22:54
Hallo uwe,

danke für Deine Erklärung.

Mir ist ein Fehler bei meiner Antwort unterlaufen.

Bisher hatte ich das natürlich nicht mittels Locate gemacht, sondern ich bin alle Datensätze durchgegangen und habe mit dem jeweils nächsten abgeglichen und dann immer die höhere Kundennummer als neue Referenz benutzt:

Delphi-Quellcode:
var
 Dummy_MaxStr : String;
 Dummy_MaxInt: Integer;
begin

 Dummy_MaxInt := 0;
 ABSTable1.Open;
 ABSTable1.First;
 repeat
  Dummy_MaxStr := ABSTable.FieldByName('KUNDENNUMMER').AsString;
  if isinteger(Dummy_MaxStr) then
   if Dummy_MaxStr.ToInteger > Dummy_MaxInt then
    Dummy_MaxInt := Dummy_MaxStr.ToInteger;
  ABSTable.Next;
 until ABSTable1.EOF;

 ShowMessage(Dummy_MaxInt.ToString);


Das hatte ich bisher in etwa so gemacht, hatte aber bei einer großen Datenbank lange gedauert.

LG
Mathias
Ich vergesse einfach zu viel.
  Mit Zitat antworten Zitat
Frickler

Registriert seit: 6. Mär 2007
Ort: Osnabrück
627 Beiträge
 
Delphi XE6 Enterprise
 
#4

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 08:16
Da wäre es ja wesentlich einfacher (und vermutlich auch schneller) gewesen, einen Index auf die Kundennummer zu setzen und dann zum letzten Datensatz zu springen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 08:29
Da wäre es ja wesentlich einfacher (und vermutlich auch schneller) gewesen, einen Index auf die Kundennummer zu setzen und dann zum letzten Datensatz zu springen.
In diesem fall schon. Ich vermute mal bei der Kundennummer ist dies schon der Fall. Aber allgemien macht es u.U. nicht unbedingt Sinn extra einen Index anzulegen.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von NoGAD
NoGAD

Registriert seit: 31. Jan 2006
Ort: Weimar
345 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 10:34
Wegen des Index muss ich dich zugeben, dass ich noch nicht weiß, was dies bewirkt, noch wie die Struktur korrekt eingesetzt werden kann.
Mathias
Ich vergesse einfach zu viel.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 10:38
Ein Index beschleunigt die Suche. Ist wie ein Inhaltsverzeichnis über Spalteninformationen.

Dieser wird bei Abfragen verwendet. Bei "klassischen tabellenbasierten" datenbanksystemen war die Reighenfolge in der Tabelle in der Reihenfolge des Primärschlüssels.
Markus Kinzler
  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 11:11 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-2025 by Thomas Breitkreuz