![]() |
AW: Datum liegt als String vor
Zitat:
Du brauchst das umgekehrte. Du hast einen String mit einer Formatierung und eine Date Funktion, die eine bestimmte Formatierung erwartet. Propier das aus:
Code:
Wie gesagt, Du warst schon auf der richtigen Spur, aber hast Dein Datum nicht "mundgerecht" für DATE() aufbereitet.create table meindatum(datum varchar(10)); insert into meindatum values('2018-12-28'); insert into meindatum values('28.12.2018'); select date(datum), date ( substr(datum, 7,4)||'-'|| substr(datum, 4,2)||'-'|| substr(datum, 1,2)) from meindatum; |
AW: Datum liegt als String vor
Ich seh keine richtige Spur :wink:
Mein Problem ist doch: Wie kann/muss ich eins der oben angegebenen Felder in der Abfrage umwandeln um mit diesen Daten rechnen zu können. Feld Inhalt Z.B. vergangene Tage von Datum "01.08.2019" bis heute ? Wie muss ich denn das Feld Datum umwandeln um diese Abfrage zum laufen zu bringen ? Ich verstehe es nicht. |
AW: Datum liegt als String vor
strftime formatiert einen Datumswert, der bereits als Date/Time Type vorliegt. Genau das ist bei Dir nicht der Fall. Deine Datumswerte sind String.
Eine Funktion, die aus einem String ein Datum macht, muss wissen, welcher Wert an welcher Position steht. DATE() von SQLite fackelt nicht lang, sondern gibt das einfach vor: YYYY-MM-DD Ist Dein Datum als Stringwert anders aufgebaut, als diese Vorgabe, musst Du es anpassen, wie Du selbst schon versucht hast, Du hast nur nicht die Vorgabe getroffen. Hier ist das Verfahren auch für Deine Where Clause angewendet:
Code:
select datum, -- der pure String, das "Problemdatum"
date(datum), -- benutzen, wenn Datumsstring bereits richtig formatiert ist -- ist in Deinen Daten nicht der Fall, --sondern: date(substr(datum, 7, 4) || '-' || -- dann selbst das notwendige Format zusammenstellen substr(datum, 4, 2) || '-' || substr(datum, 1, 2)) from meindatum -- geht auch in der Where Clause where date(substr(datum, 7, 4) || '-' || -- baue ein echtes Datum aus Deinen Daten substr(datum, 4, 2) || '-' || substr(datum, 1, 2)) -- und rechne oder vergleiche damit between date('2018-12-01') and date('2018-12-31') -- hier kann man die Datumsgrenzen als String gleich im richtigen Format angeben |
AW: Datum liegt als String vor
Danke JOBO !!!!
mit so einer Erklärung anhand eines Beispiels - hab ich es kapiert !!! Mit solchen Antworten kann man lernen und kapieren 1 mit Sternchen |
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:00 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