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
Seite 2 von 3     12 3      
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.275 Beiträge
 
Delphi 10.4 Sydney
 
#11

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 17:00
Hallo,
liefert eben keinen Record

Doch, genau einen Rekord mit einem Feld.

*krümelkacker" aus
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von NoGAD
NoGAD

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 17:14
Die Lösung von Uwe hat mir sehrr geholfen.

Dadurch kann ich nun auf den kompletten Record zugreifen.

Ich wusste einfach nicht, dass nach einem Select MAX(... der Record nicht alle Spalten ermöglicht.

Bisher hatte ich immer mit ABSTable gearbeitet.

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.442 Beiträge
 
Delphi 12 Athens
 
#13

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 18:07
Bisher hatte ich immer mit ABSTable gearbeitet.
Und wie hast du es da gemacht?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 18:19
select top 1,1 * from dbKunden order by KUNDENNUMMER desc;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von NoGAD
NoGAD

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 22: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 NoGAD
NoGAD

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 22:30
select top 1,1 * from dbKunden order by KUNDENNUMMER desc;
Hallo Markus, kannst Du mir das bitte erklären, was diese Abfrage macht?

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.442 Beiträge
 
Delphi 12 Athens
 
#17

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 22: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
 
#18

AW: Abfrage mittels SQL - Ergebnis?

  Alt 21. Apr 2022, 23: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
mkinzler
(Moderator)

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 07:41
select top 1,1 * from dbKunden order by KUNDENNUMMER desc;
Hallo Markus, kannst Du mir das bitte erklären, was diese Abfrage macht?

LG
Es sortiert die Kundennummern von groß nach klein und liefert dann den 1. Datensatz (höchster Wert)
Markus Kinzler
  Mit Zitat antworten Zitat
Frickler

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

AW: Abfrage mittels SQL - Ergebnis?

  Alt 22. Apr 2022, 09: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
Antwort Antwort
Seite 2 von 3     12 3      


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 02:54 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