AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FreePascal Die letzte Zeile aus der DB schnell auslesen?
Thema durchsuchen
Ansicht
Themen-Optionen

Die letzte Zeile aus der DB schnell auslesen?

Ein Thema von AlexII · begonnen am 6. Jan 2015 · letzter Beitrag vom 7. Jan 2015
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.373 Beiträge
 
Delphi 12 Athens
 
#1

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:47
Laut Beschreibung/Überschrift woller er ja nicht die größte Nummer, sondern die Letzte, also
SELECT knr FROM tbteilnehmer ORDER BY xxx DESC LIMIT 1
xxx = akn
oder nach was auch immer die Daten sortiert sein sollen (z.B. insert_date oder so)


Ansonsten wäre sein Code auch irgendwie falsch.
Delphi-Quellcode:
LastKNr := -1; // warum hast du die Variable nicht initialisiert? Was soll denn rauskommen, wenn es keine Datensätze gibt!
while not SQLQueryLastKNr.Eof do
begin
  if LastKNr < SQLQueryLastKNr.FieldByName('knr').AsInteger then
    LastKNr := SQLQueryLastKNr.FieldByName('knr').AsInteger;
  SQLQueryLastKNr.Next;
end;
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu ( 6. Jan 2015 um 13:49 Uhr)
  Mit Zitat antworten Zitat
AlexII

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

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:48
Habe diese Selektion gefunden, die gut funktioniert.

SELECT knr FROM tbteilnehmer WHERE id_teilnehmer=(SELECT MAX(id_teilnehmer) FROM tbteilnehmer)

Die id_teilnehmer hat wohl den Index, die knr nicht wie es scheint.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.373 Beiträge
 
Delphi 12 Athens
 
#3

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:52
SELECT knr FROM tbteilnehmer ORDER BY id_teilnehmer DESC LIMIT 1 (Beschreibung siehe Nachtrag meine letzter Antwort)
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
AlexII

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

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:56
SELECT knr FROM tbteilnehmer ORDER BY id_teilnehmer DESC LIMIT 1 (Beschreibung siehe Nachtrag meine letzter Antwort)
Was heißt "DESC LIMIT 1"?
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.659 Beiträge
 
Delphi 12 Athens
 
#5

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:57
Absteigend sortieren und nur den 1. Datensatz zurückgeben.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
AlexII

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

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:59
Absteigend sortieren und nur den 1. Datensatz zurückgeben.
Ich Suche aber nach dem letzten Datensatz.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 14:02
Wenn absteigend sortiert ist, ist der erste der größte!

Gruß
K-H

P.S.
nochmal den "letzten" gibt es in einer Datenbank nicht!
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.222 Beiträge
 
Delphi 10.4 Sydney
 
#8

AW: Die letzte Zeile aus der DB schnell auslesen?

  Alt 6. Jan 2015, 13:57
Limit: http://www.mysqltutorial.org/mysql-limit.aspx
Desc: http://www.w3schools.com/sql/sql_orderby.asp
Windows Vista - Eine neue Erfahrung in Fehlern.
  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 22:59 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