AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FreePascal Wie am besten ein Datum und eine Uhrzeit in der DB speichern?
Thema durchsuchen
Ansicht
Themen-Optionen

Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

Ein Thema von AlexII · begonnen am 20. Nov 2014 · letzter Beitrag vom 21. Nov 2014
Antwort Antwort
Seite 2 von 2     12   
mkinzler
(Moderator)

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:04
Werte immer im entsprechenden Typen speichern!
Bei der Speicherung als Text handelst Du dir nur ein enormes Fehlerpotential ein.
Die Speicherung als DateTime hat den Vorteil, dass diese unabhängig vom Datumsformat ist ( Sprache, Kurz-/Langformat, ...)
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:04
Man hätte DateTime nicht erfunden, wenn es nicht sinnvoller wäre als Text.

- frei formatierbar in der Darstellung
- Zeitzonen unabhängig
- sortierbar
- man kann damit rechnen

Das sind so auf die Schnelle Vorteile, die mir dazu einfallen.
Hinter dir gehts abwärts und vor dir steil bergauf ! (Wolfgang Ambros)
  Mit Zitat antworten Zitat
AlexII

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:22
Ok... dann lässt sich wohl auch die Suche in dem DateTime Feld realisieren, muss nur rausfinden wie. ))

Danke Euch!
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:33
Was willst Du darin suchen? Du kannst anhand des Wertes Suchen/Filtern (between usw.)
Markus Kinzler
  Mit Zitat antworten Zitat
AlexII

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:35
Was willst Du darin suchen? Du kannst anhand des Wertes Suchen/Filtern (between usw.)
Habe mich falsch ausgedruckt, selectieren möchte ich, z.B. alle Einträge von 15.11.2014 bis 20.11.2014 ))
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:37
Aus der SQLite Dokumentation:

Zitat:
1.2 Date and Time Datatype

SQLite does not have a storage class set aside for storing dates and/or times. Instead, the built-in Date And Time Functions of SQLite are capable of storing dates and times as TEXT, REAL, or INTEGER values:

TEXT as ISO8601 strings ("YYYY-MM-DD HH:MM:SS.SSS").
REAL as Julian day numbers, the number of days since noon in Greenwich on November 24, 4714 B.C. according to the proleptic Gregorian calendar.
INTEGER as Unix Time, the number of seconds since 1970-01-01 00:00:00 UTC.

Applications can chose to store dates and times in any of these formats and freely convert between formats using the built-in date and time functions.
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 Luckie
Luckie

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:46
Was spricht gegen eine Timestamp? Ganz ungünstig ist es als vorformatiertes Format abspeichern. dann musst du es jedes mal auseinander nehmen und wieder zusammensetzen, wenn es anders dargestellt werden soll. Fängt schon damit an, wenn du nur das Jahr brauchst. Für Timestamps gibt es fertige Funktionen bzw. man schreibt sie sich einmal und fertig. Die sonstigen Vorteile wurden ja schon genannt.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
AlexII

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

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 20. Nov 2014, 12:52
Aus der SQLite Dokumentation:

Zitat:
1.2 Date and Time Datatype

SQLite does not have a storage class set aside for storing dates and/or times. Instead, the built-in Date And Time Functions of SQLite are capable of storing dates and times as TEXT, REAL, or INTEGER values:

TEXT as ISO8601 strings ("YYYY-MM-DD HH:MM:SS.SSS").
REAL as Julian day numbers, the number of days since noon in Greenwich on November 24, 4714 B.C. according to the proleptic Gregorian calendar.
INTEGER as Unix Time, the number of seconds since 1970-01-01 00:00:00 UTC.

Applications can chose to store dates and times in any of these formats and freely convert between formats using the built-in date and time functions.
Das hat auch meine Frage ausgelöst. Aber weiter unten auf der Seite ist in der Tabelle DateTime vorhanden, SQLite akzeptiert das auch, also habe ich DateTime genommen.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.643 Beiträge
 
#9

AW: Wie am besten ein Datum und eine Uhrzeit in der DB speichern?

  Alt 21. Nov 2014, 07:04
Ok... dann lässt sich wohl auch die Suche in dem DateTime Feld realisieren, muss nur rausfinden wie. ))
Ist relativ einfach:

Code:
SELECT Col1, Col1
FROM MyTable
WHERE DateField >= '2014-11-21 06:00';

-- oder

SELECT Col1, Col1
FROM MyTable
WHERE DateField BETWEEN '2014-11-01 06:00' AND '2014-11-05 18:00';
Eine Sache solltest Du Dir vorher noch überlegen: Könntest Du, möglicherweise, unter irgendwelchen Umständen, vielleicht, mal auf die Idee kommen, zum einen unterschiedliche Zeitzonen zu bearbeiten? Oder musst Du die Einträge in der doppelten Stunde bei einer Zeitumstellung auf Winterzeit (also zwischen 2 und 3 Uhr an einem Sonntag) in die richtige Reihenfolge bringen können? Also willst Du bei zwei Einträgen um jeweils 02:15 Uhr wissen, welches der beiden 02:15 vor oder nach der Zeitumstellung war?

Falls Du eines der beiden mit Ja beantworten kannst, dann solltest Du alle Zeiten vor der Ablage in der Datenbank in UTC konvertieren. Dann musst Du zwar die Daten vor der Anzeige immer wieder in lokale Zeit umrechnen, aber dafür gibt es in den DateUtils ein paar passende Funktionen, die das recht einfach machen. Der Vorteil ist halt, dass Du immer genau weisst, was da in der DB steht.
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 06:16 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