AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Datum autom. ausrechnen
Thema durchsuchen
Ansicht
Themen-Optionen

Datum autom. ausrechnen

Ein Thema von manfred_h · begonnen am 3. Aug 2009 · letzter Beitrag vom 5. Aug 2009
Antwort Antwort
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#1

Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:11
Datenbank: Firebird • Version: 2.1 • Zugriff über: Fibplus
Hallo zusammen

in meiner Anwendung verwende ich folgenden Code um von einem Datum "maxdate" ein paar Monate dazuzurechnen.
> (FieldByName('CS').Value * 30) // CS glein eine Anzahl von Monaten.

Leider besteht das Problem das dies ab und zu nicht geht. Mir ist nicht ganz klar wieso.

Delphi-Quellcode:
procedure TDM.main_nc_calc(Sender: TObject);
var maxdate : string;
    d_accept : string;
begin
  with Q_tmp do
  begin
    SQL.Text := ('SELECT MAX( D_DATE ) MAX_OF_D_DATE, D_ACCEPTANCE FROM '+ sql_string_table_d +' WHERE' +
                 '(ID_AREA = '+''''+(''+id_value+''''+')')+
                 'GROUP BY D_ACCEPTANCE ORDER BY 1 DESC');
    ExecQuery;
    Close;
    d_accept := Q_tmp.FieldByName('D_ACCEPTANCE').AsString;
    maxdate := Q_tmp.FieldByName('MAX_OF_D_DATE').AsString;
  end;
  if maxdate > '1then
    with tmp do
    begin
      Close;
      SelectSQL.Clear;
      SelectSQL.Add (sql_string_table);
      AutoUpdateOptions.UpdateTableName := (table_name);
      Open;
    end;
    tmp.Open;
    Camps.Open;
    with tmp do
    begin
      Edit;
      FieldByName('NC').AsString := DateToStr(StrToDate(maxdate)+((FieldByName('CS').Value * 30)));
      FieldByName('ACCEPTANCE').AsString := d_accept;
      post;
    end;
end;
habt Ihr mir einen Tipp?

Manfred
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:15
Wieso nutzt Du nicht DateUtils (IncMonths oder so ähnlich, kann gerade nicht nachsehen). Und wieso hantierst Du da umständlich mit Strings herum?
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
mkinzler
(Moderator)

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

Re: Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:19
Es gibt in FireBird Datumsfunktionen, entweder als UDF oder in neueren Versionen direkt.
Select DateAdd( <month, <Monate>, <Datumsfeld>) ... from <tabelle> ...;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:20
Das ist natürlich noch besser, war mir komplett entfallen.
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
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:20
Zitat:
Leider besteht das Problem das dies ab und zu nicht geht
Selbst meine Glaskugel verrät mit nicht was hinter der Aussage steckt.
Im Ernst. "geht nicht" ist keine besonder geeignete Fehlerbeschreibung wenn man Hilfe erwartet. Welcher Fehler wird dir denn angezeigt oder was soll passieren und was passiert tatsächlich?
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#6

Re: Datum autom. ausrechnen

  Alt 3. Aug 2009, 18:31
Zitat von SirThornberry:
Zitat:
Leider besteht das Problem das dies ab und zu nicht geht
Selbst meine Glaskugel verrät mit nicht was hinter der Aussage steckt.
Im Ernst. "geht nicht" ist keine besonder geeignete Fehlerbeschreibung wenn man Hilfe erwartet. Welcher Fehler wird dir denn angezeigt oder was soll passieren und was passiert tatsächlich?
Das Problem ist das kein Fehler angezeit wird sondern einfach kein Resultat.
Werde aber die obigen Vorschläge versuchen.

Die Funktion
Select DateAdd( <month, <Monate>, <Datumsfeld>) ... from <tabelle> ...; sieht sehr interessat aus. Werde das mal ein wenig anschauen.
Besten Dank schon mal.

Shalom
Manfred
  Mit Zitat antworten Zitat
manfred_h

Registriert seit: 4. Nov 2005
Ort: Basel
442 Beiträge
 
Delphi XE2 Enterprise
 
#7

Re: Datum autom. ausrechnen

  Alt 5. Aug 2009, 09:41
Danke Euch allen für die Hilfe.
Momentan habe ich es so gelöst:
FieldByName('NC').AsDateTime := IncMonth(maxdate, +(FieldByName('CS').Value)); @mkinzler Die Lösung von Dir finde ich sehr elegant und werde diese auch noch Testen.

Besten dank nochmals für Eure schnelle Hilfe !
Shalom
Manfred
  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 03:26 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