AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi IsEmpty funktioniert nicht bei SELECT MAX ...
Thema durchsuchen
Ansicht
Themen-Optionen

IsEmpty funktioniert nicht bei SELECT MAX ...

Ein Thema von divBy0 · begonnen am 28. Aug 2009 · letzter Beitrag vom 28. Aug 2009
Antwort Antwort
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#1

IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 14:37
Datenbank: SQLite • Version: 3 • Zugriff über: Zeos
Hallo,

ich habe ein kleines Problem.

Eine einfache Abfrage 'SELECT MAX(Id) FROM barcodes' soll die höchste ID zurückliefern, dass funktioniert wenn mind. ein Eintrag in der Datentabelle besteht.

Mein Problem ist jetzt, dass es vorkommen kann, dass kein Eintrag in der Datentabelle steht und dann habe ich ein Problem, da ich beim Übernehmen in eine Integervariable eine Fehlermeldung "Ist kein gültiger Integerwert" bekomme.

Wie kann ich denn prüfen, ob ein Wert zurückkam.

Mit ZQuery.IsEmpty und ZQuery.RecNo funktioniert das leider nicht.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 14:47
Frag den Spaltenwert doch als String ab und wende selbst StrToIntDef(Wert, 0) an.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#3

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 15:00
So habe ich es jetzt gelöst, aber das gefällt mir nicht so wirklich.

Ich dachte da gibts was eleganteres.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es
  Mit Zitat antworten Zitat
hoika

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

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 15:17
Hallo,

das ist aber wohl SQL-Standard Max(NULL) = NULL
(0 darf er nicht, es könnte ja ein Datensatz mit genau 0 drinstehen).

Select Max() liefert NULL, wenn keine Datensätze in der Tabelle sind.

Fields[0].IsNull sollte funktionieren.


Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#5

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 15:23
Danke! Das ist es.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es
  Mit Zitat antworten Zitat
Benutzerbild von HeikoAdams
HeikoAdams

Registriert seit: 12. Jul 2004
Ort: Oberfranken
661 Beiträge
 
FreePascal / Lazarus
 
#6

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 15:26
Zitat von hoika:
Fields[0].IsNull sollte funktionieren.
Vielleicht nicht ganz so elegant, aber
VarIsNull(FieldByName('xy').AsVariant) sollte genau so gut funktionieren.
Jeder kann ein Held werden und Leben retten!
Einfach beim NKR oder der DKMS als Stammzellenspender registrieren! Also: worauf wartest Du noch?
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#7

Re: IsEmpty funktioniert nicht bei SELECT MAX ...

  Alt 28. Aug 2009, 17:00
Zitat von divBy0:
...aber das gefällt mir nicht so wirklich. Ich dachte da gibts was eleganteres.
Zuerst prüfen, ob Feld "Anzahl" <> 0 und falls ja, Feld "MaxID" auslesen.SELECT MAX(Id) AS MaxID, Count(*) AS Anzahl FROM barcodes
Andreas
  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 07:19 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