Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Realzahl in Datum wandeln SQLLite (https://www.delphipraxis.net/192175-realzahl-datum-wandeln-sqllite.html)

Emsbootsmann 26. Mär 2017 15:17

Datenbank: SQLlite3 • Version: 1 • Zugriff über: delphi 5

Realzahl in Datum wandeln SQLLite
 
ich habe folgendes Problem und suche schon den ganzen Tag nach einer Lösung.
Wenn ich in eine SQLLite Datenbank das Datum in der Struktur Date eingeben, wird es mir in der Tabelle richtig angezeigt. Im Datenbankbrowser da das Datum 17.03.2016 mit 2457829.5.Nun möchte ich bei der Suche im Edit1.text
"17.03" eingeben und dann soll er diesen Datensatz finden. Dafür müsste ich den Realwert in Datum wandeln aber wie.

DeddyH 26. Mär 2017 15:28

AW: Realzahl in Datum wandeln SQLLite
 
Sorry, aber... hä? Was gibst Du wo ein, und wie wird es dann dargestellt? SQLite kennt keinen expliziten Date-/DateTime-Typen (siehe Doku Punkt 2.2), ich nehme dafür immer die TEXT-Variante, die lässt sich IMO am einfachsten ohne großes Gehampel kontrollieren.

haentschman 26. Mär 2017 15:56

AW: Realzahl in Datum wandeln SQLLite
 
Moin...:P
Zitat:

"17.03" eingeben und dann soll er diesen Datensatz finden.
"17.03"...2017, 1918, 1534...? :gruebel: So kannst das Datum in der Datenbank nicht eindeutig identifizieren. :?

Was hast du den vor?

nahpets 26. Mär 2017 17:31

AW: Realzahl in Datum wandeln SQLLite
 
Delphi-Quellcode:
Datum := StrToDateTime(Edit1.text);
Wenn in Edit1.Text ein gültiges Datum steht, dann könnte das funktionieren.

Wenn nur 17.03 eingegeben wird, wie sollen Programm und / oder Datenbank den "wissen" aus welchem Jahr der 17.03 gesucht werden soll?

Emsbootsmann 26. Mär 2017 20:50

AW: Realzahl in Datum wandeln SQLLite
 
Liste der Anhänge anzeigen (Anzahl: 1)
im Anhang mein Problem,ich muss zum sortieren das Datumsfeld haben.im oberen Teil ist zu sehen wie es im DBGrid
aussieht unten wie in der Datenbank.Nun möchte ich im Datumsfeld der SQL Datenbank sichen nach Datum aber er kennt dort ja nur die Zahl.
Zu suche Datum like "'+AFWerte[4]+'"'; Entspricht alles anzeigen was im Datumsfeld 17.03 hat

nahpets 26. Mär 2017 21:35

AW: Realzahl in Datum wandeln SQLLite
 
In den Zahlen kann man nicht mit Like und Teilstrings suchen.

Wenn eine Suche mit Like erforderlich ist, muss man das Datum als Zeichenfolge speichern oder jeweils umwandeln.

Ausgehend von dieser Seite https://www.sqlite.org/datatype3.html, könnte es sich bei dem Datumswert in Deiner Datenbank um folgendes handeln:
Zitat:

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.
Schau mal bitte hier https://www.techonthenet.com/sqlite/functions/time.php, ob dort eine passende Funktion zu finden ist, mit der Du in einer Abfrage das Datum aus der Datenbank in eine Zeichenfolge verwandeln kannst, die dann mit Like genutzt werden kann.

Sowas in der Art:
SQL-Code:
select * from tabelle where Date(Datumspalte,'DD.MM.YYYY') like '17.03%'

p80286 26. Mär 2017 21:59

AW: Realzahl in Datum wandeln SQLLite
 
Zitat:

Zitat von nahpets (Beitrag 1365590)
Sowas in der Art:
SQL-Code:
select * from tabelle where Date(Datumspalte,'DD.MM.YYYY') like '17.03%'

Nichts für ungut, ich hab gerade versucht mich in SQLLite zu orientieren. "Date" wäre eine Funktion die ein Datum zurück liefert was als String eingegeben wurde. ich vermute, wir brauchen printf um den String zu generieren in dem gesucht werden kann.

Gruß
K-H

nahpets 26. Mär 2017 22:12

AW: Realzahl in Datum wandeln SQLLite
 
printf kann ich irgendwie nicht finden, egal, kenne mich mit SQLite wohl nicht wirklich aus. Benötigt wird wohl das Gegenstück zu
SQL-Code:
sqlite> SELECT julianday('2016-10-18 16:45:30');
Result: 2457680.19826389
Könnte das dashier sein?
SQL-Code:
sqlite> SELECT strftime('%Y-%m-%d %H:%M', 'now');
Result: '2017-03-07 20:14'    (formatted as YYYY-MM-DD HH:MM)
Also hier ungefähr sowas?
SQL-Code:
select * from tabelle where strftime('%d.%m.%y',Datumsspalte) like '17.03%'

hoika 27. Mär 2017 04:07

AW: Realzahl in Datum wandeln SQLLite
 
Hallo,
warum nimmst du nicht strftime und dort nur dd.mm. ?
Dann vergleichst du das mit 17.03.
Den ganzen %-Kram kannst du dir dann sparen.

Emsbootsmann 27. Mär 2017 07:25

AW: Realzahl in Datum wandeln SQLLite
 
so richtig funktioniert es noch nicht aber erstmal herzlichen Dank für eure hilfe


Alle Zeitangaben in WEZ +1. Es ist jetzt 23:36 Uhr.
Seite 1 von 2  1 2      

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