![]() |
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. |
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
![]() |
AW: Realzahl in Datum wandeln SQLLite
Moin...:P
Zitat:
Was hast du den vor? |
AW: Realzahl in Datum wandeln SQLLite
Delphi-Quellcode:
Wenn in Edit1.Text ein gültiges Datum steht, dann könnte das funktionieren.
Datum := StrToDateTime(Edit1.text);
Wenn nur 17.03 eingegeben wird, wie sollen Programm und / oder Datenbank den "wissen" aus welchem Jahr der 17.03 gesucht werden soll? |
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 |
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 ![]() Zitat:
![]() Sowas in der Art:
SQL-Code:
select * from tabelle where Date(Datumspalte,'DD.MM.YYYY') like '17.03%'
|
AW: Realzahl in Datum wandeln SQLLite
Zitat:
Gruß K-H |
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:
Könnte das dashier sein?
sqlite> SELECT julianday('2016-10-18 16:45:30');
Result: 2457680.19826389
SQL-Code:
Also hier ungefähr sowas?
sqlite> SELECT strftime('%Y-%m-%d %H:%M', 'now');
Result: '2017-03-07 20:14' (formatted as YYYY-MM-DD HH:MM)
SQL-Code:
select * from tabelle where strftime('%d.%m.%y',Datumsspalte) like '17.03%'
|
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. |
AW: Realzahl in Datum wandeln SQLLite
so richtig funktioniert es noch nicht aber erstmal herzlichen Dank für eure hilfe
|
AW: Realzahl in Datum wandeln SQLLite
Zitat:
Das Teildatum so anreichern, dass es ein gültiges Datum ergibt und zwar den Start einer Bereichssuche, korrespondierend einen 2.Wert bauen, der das Ende des Bereiches darstellt. Ergibt für einen Tagesbereich bspw. solch ein Statement:
Code:
//delphi pseudocode
Var startDateRange, endDateRange :TDate begin startDateRange := EditText+'.2016'; endDateRange := startDateRange + 1 Tag;
Code:
Die Anreicherung und Konvertierung des Eingabestrings kann man natürlich auch im SQL Statement selbst durchführen.
--SQL Statement
select * from mytable x where x.mydate between :pStartDate and :pEndDate Wichtig ist, bestimmte Prinzipien zu berücksichtigen. Kein Like, sondern Bereichssuche mit ><= oder between im SQL. Bereichserzeugung (Parameterwerte) geht idR recht einfach, sobald man echte Datumswerte erzeugt hat, dann kan man damit einfach rechnen, das gilt sowohl für SQL als auch für Delphi. In SQL stehen dazu -meist Datenbank spezifisch- eine ganze Reihe von Hilfsfunktionen zur Verfügung. |
AW: Realzahl in Datum wandeln SQLLite
Nun der Wunsch nach dem "17.3" ist als solches ja schon seltsam.
Meiner Meinung nach müßte man den 17.3.2015,17.03.2016 (oder besser 2015-03-17,2016.03.17) usw. suchen. Das "Like " sehe ich als berechtigte Visualisierung eines vergewaltigten DB-Feldes. Gruß K-H |
AW: Realzahl in Datum wandeln SQLLite
Zitat:
Hier ist eigentlich noch die Aufgabenstellung unklar. Wenn nach 17.03 gesucht wird, heißt das, dass alle Datensätze zu allen 17.03 aller Jahre gefunden werden sollen? Oder will man hier dem Anwender nur die Eingabe von 5 weiteren Zeichen ersparen, also eine unsinnige Faulheit unterstützen? Dann scheidet das von Jobo zu Sprache gebrachte Between leider aus. Wenn man nach einem Datum sucht, dann sollte man auch dieses Datum eingeben und nicht nur 'ne Teilmenge, in der Hofflung: Die DB wird's schon richten. Alternative: Datum als Zeichenfolge in der DB ablegen in der Form YYYYMMDD. Dann kann man auch mit Teilzeichenfolgen und Between sinnvoll und (vermutlich) performant suchen. Aus der Eingabe 2017 wird dann per Programmcode Between '20170101' and '20171231'. Aus der Eingabe von 201703 wird Between '20170301' and '20170331'. So kann man sinnvoll nach einem konkreten Datum suchen oder auch nach Datumsbereichen von-bis. Die einzige Verwendung von Eingaben ala 17.03 erscheint mir bei einer Kalendersuche die Suche nach bestimmten Jahrestagen zu sein. Sowas in der Art: Wer ist alles am 17.03 geboren. Also sowas: ![]() ![]() |
AW: Realzahl in Datum wandeln SQLLite
Hallo,
warum sollte die Aufgabenstellung seltsam sein? Den Bug habe ich am 17.03. eingebaut, aber welches Jahr ... ? ;) Noch mal zum Thema: select * from tabelle where strftime('dd.mm',Datumsspalte) = '17.03' Das sollte doch gehen? |
AW: Realzahl in Datum wandeln SQLLite
Zitat:
Naheliegend find ich hier, das Datum des aktuellen Jahres ist gemeint bzw. ist ja 2016 im EP explizit genannt. Ich gehe mal davon aus, der TE wird schon wissen was er sucht und kann meinen Beispielcode entsprechend abändern, wenn es dann doch ein anderes oder viele Jahre sein sollen. Mir ging es wie geschrieben primär um die Frage, wie man grundsätzlich eine solche Aufgabe lösen kann ohne dass gleich Vergelwaltigung im Spiel ist. Angenommen, es soll doch nach allen 17.3. Vorkommen in allen Jahren gesucht werden, ist mein Vorschlag "etwas umständlich", aber das könnten wir noch herausfinden, falls der TE sich jemals wieder meldet. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:10 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