AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Als String abgelegtes Datum vergleichen

Ein Thema von Bufo · begonnen am 3. Sep 2007 · letzter Beitrag vom 3. Sep 2007
Antwort Antwort
Bufo

Registriert seit: 7. Mai 2006
27 Beiträge
 
#1

Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 03:31
Hallo,

ich möchte ein in einer DB als alphanumerischen Wert abgelegtes Datum mit einem vorgegebenen Datum vergleichen. Definiere ich dieses ebenfalls als String (Format dd.mm.yy), werden nur die Stellen vor dem ersten Punkt (dd) berücksichtigt. Versuche ich, das Datum aus der DB mit StrToDate umzuwandeln, bekomme ich eine Fehlermeldung. Code:


.............
S.Text:= 'SELECT AnnDat, Name, Vorname,Smile,Plz,Ort,Strasse, Status,AFTyp FROM' +''''+DBPfadAUftr+''' WHERE (AFTyp = "WZ-Wartung" AND (StrToDate(AnnDat)) < ''30.12.2006'')';

QueryAuftr.Active:=false;
QueryAuftr.SQL:=S;
QueryAuftr.Active:= true;.......


Was mache ich falsch???

Danke schon mal!
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 04:17
Das ist keine Fehlermeldung.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 07:36
Du kannst keine Delphi-Funktionen in einem SQL-Abfrage verwenden.
Warum legst du das Datum als String in der Datenbank ab?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 08:08
Hi,

wie du im Select einen String in ein Datum umwandelst, hängt von der DB ab.
Meist ist das ein Cast(Stringtyp as Date).
Also etwa so:
(AFTyp = "WZ-Wartung" AND Cast(AnnDat as Date) < ''30.12.2006'')... Was man aber auch vermeiden sollte, ist ein Umbiegen des Zeigers:

QueryAuftr.SQL:=S; Besser ist:
QueryAuftr.SQL.Assign(S);
Frank
Frank Reim
  Mit Zitat antworten Zitat
Bufo

Registriert seit: 7. Mai 2006
27 Beiträge
 
#5

Re: Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 12:17
Danke, klappt hervorragend!!!!
  Mit Zitat antworten Zitat
Gruber_Hans_12345

Registriert seit: 14. Aug 2004
1.439 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Als String abgelegtes Datum vergleichen

  Alt 3. Sep 2007, 12:37
Zitat von dataspider:
Was man aber auch vermeiden sollte, ist ein Umbiegen des Zeigers:

QueryAuftr.SQL:=S; Besser ist:
QueryAuftr.SQL.Assign(S); Frank
also das "direkte" setzen von SQL ist kein problem, da es sich dabei fast immer um ein property handelt, das im setter dann selber das assign durchführt - sprich es werden keinerlei zeiger verbogen dabei
Gruss Hans

2B or not 2B, that is FF
  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:49 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