AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

Datum liegt als String vor

Ein Thema von concept2015 · begonnen am 13. Aug 2019 · letzter Beitrag vom 13. Aug 2019
Antwort Antwort
Seite 2 von 2     12
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#11

AW: Datum liegt als String vor

  Alt 13. Aug 2019, 13:34
Irgendwas falsch beim konvertieren !
Das Datum liegt so 12.08.2019 als String vor.




SELECT Datum,wer
FROM zwischen
WHERE strftime("%Y.%m.%d",Datum) = "12.08.2019"

<No Data to Display>

Auch mit: strftime("%d.%m.%Y",Datum)

<No Data to Display>
Nein, Du verwendest die Funktion falsch bzw. die falsche Funktion. Schau dir die Signaturen der Funktionen an. strftime erwartet datetime typen und stellt sie in der gewünschten Formatierung dar.
Du brauchst das umgekehrte.
Du hast einen String mit einer Formatierung und eine Date Funktion, die eine bestimmte Formatierung erwartet.

Propier das aus:
Code:

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;
Wie gesagt, Du warst schon auf der richtigen Spur, aber hast Dein Datum nicht "mundgerecht" für DATE() aufbereitet.
Gruß, Jo
  Mit Zitat antworten Zitat
concept2015

Registriert seit: 22. Dez 2015
Ort: Nähe Dortmund
44 Beiträge
 
Delphi 7 Professional
 
#12

AW: Datum liegt als String vor

  Alt 13. Aug 2019, 14:20
Ich seh keine richtige Spur

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.
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#13

AW: Datum liegt als String vor

  Alt 13. Aug 2019, 14:48
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
Gruß, Jo
  Mit Zitat antworten Zitat
concept2015

Registriert seit: 22. Dez 2015
Ort: Nähe Dortmund
44 Beiträge
 
Delphi 7 Professional
 
#14

AW: Datum liegt als String vor

  Alt 13. Aug 2019, 15:23
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
  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 11:10 Uhr.
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