AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken TDatefield, nur Jahreszahl anzeigen und übergeben

TDatefield, nur Jahreszahl anzeigen und übergeben

Ein Thema von Trafel21 · begonnen am 11. Nov 2019 · letzter Beitrag vom 11. Nov 2019
Antwort Antwort
Trafel21

Registriert seit: 16. Nov 2018
65 Beiträge
 
#1

TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 11:20
Datenbank: firebird • Version: 2.5 • Zugriff über: Delphi XE
Hallo zusammen,

ich hab gerade ein verzwicktes Problem. Ich hab in der Datenbank ein DATE Feld welches ich nicht in ein Integer-Feld umändern kann.
Ich möchte über DBEditbox in Delphi nur die Jahreszahl übergeben und auch nur darstellen. in der Datenbank sollte dann 01.01."2018" gespeichert werden.

In Delphi (DataSet) ist es wie folgt definiert:
IBANSCHAFFUNGSDATUM: TDateField;

Würdet ihr die Logik in einen Trigger schreiben? oder in Delphi das 01.01. hinzufügen? Ich hab schon mehreres versucht. SetText, OnChange... irgendwie funktioniert nichts so wirklich.
Vielleicht gibt es einen eleganteren Weg, den ich noch nicht kenne? x.x
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.473 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#2

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 11:29
Nimm doch einfach eine normales Editfeld und formatiere die Anzeige.
Markus Kinzler

Geändert von mkinzler (11. Nov 2019 um 11:35 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.473 Beiträge
 
Delphi 7 Personal
 
#3

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 12:08
Ich hab in der Datenbank ein DATE Feld welches ich nicht in ein Integer-Feld umändern kann.
Warum kannst Du das nicht?
Wird das Feld durch eine andere Anwendung mi einem vollständigen Datum genutzt?
Kennt deine DB "ALTER" nicht?

Und ansonsten sollte man tunlichst die Finger von DB-Komponenten lassen, vor allem wenn man Anforderungen hat, die etwas abseits des Mainstreams liegen.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Trafel21

Registriert seit: 16. Nov 2018
65 Beiträge
 
#4

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 12:15
Ich hab in der Datenbank ein DATE Feld welches ich nicht in ein Integer-Feld umändern kann.
Wird das Feld durch eine andere Anwendung mi einem vollständigen Datum genutzt?
Genau deswegen. :/

Nimm doch einfach eine normales Editfeld und formatiere die Anzeige.
Werde ich mal so versuchen, vielen dank.
  Mit Zitat antworten Zitat
dataspider
Online

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.172 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 13:35
Ich würde hier in der DB einen View anlegen.

Ein berechnetes Feld
extract(year from fibanschaffungsdatum) as fibanschaffungsjahr...
...und das Schreiben im before update trigger der View.

Dann hast du im Dataset ein Interger - Feld und kannst dir das ganze Gefummel in Delphi sparen...

Frank
Frank Reim
  Mit Zitat antworten Zitat
Trafel21

Registriert seit: 16. Nov 2018
65 Beiträge
 
#6

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 14:18
Ich würde hier in der DB einen View anlegen.

Ein berechnetes Feld
extract(year from fibanschaffungsdatum) as fibanschaffungsjahr...
...und das Schreiben im before update trigger der View.

Dann hast du im Dataset ein Interger - Feld und kannst dir das ganze Gefummel in Delphi sparen...

Frank
vielen Dank!

Wäre es evtl. auch mit einem weiteren FEld möglich? Sowas wie

ALTER TABLE STAMM
ADD HERSTELLUNGSDATUM_JAHR COMPUTED BY ((EXTRACT(YEAR FROM STAMM.HERSTELLUNGSDATUM ))

... und im IB Stamm das schreiben mit update trigger ?
  Mit Zitat antworten Zitat
dataspider
Online

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.172 Beiträge
 
Delphi 10.3 Rio
 
#7

AW: TDatefield, nur Jahreszahl anzeigen und übergeben

  Alt 11. Nov 2019, 15:37
Wäre es evtl. auch mit einem weiteren FEld möglich? Sowas wie

ALTER TABLE STAMM
ADD HERSTELLUNGSDATUM_JAHR COMPUTED BY ((EXTRACT(YEAR FROM STAMM.HERSTELLUNGSDATUM ))

... und im IB Stamm das schreiben mit update trigger ?
Das mit dem Trigger funktioniert auf berechente Felder der Tabelle leider nicht.
Geht IMO nur über View...

Frank
Frank Reim
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 14:44 Uhr.
Powered by vBulletin® Copyright ©2000 - 2019, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2019 by Daniel R. Wolf