Hallo!
Eigentlich mache ich innerhalb meines Programmes etwas sehr simples, warum dieser Fehler auftaucht, weiß ich nicht.
Aber von Anfang an:
PHP 4.3.0
Apache 1.3.26
Datenbank MS SQL 7.0
Ich lese aus der Datenbank ein Datum aus, dass ich anschliessend ausgeben möchte.
Da ich an mehreren Stellen im Programm Datumsausgaben habe, die aus verschiedenen Tabellen kommen, deren Datumsspalten unterschiedlich formatiert sind, sind natürlich aus die Ausgaben unterschiedlich.
Das sollte allerdings einheitlich sein. Info: Leider habe ich keine Möglichkeit, die Datumsformate auf DB Ebene zu ändern.
Folgendes wollte ich machen:
- Datum in Array splitten
- Monatsname durch Zahl ersetzen (Funktion check_month(Monat))
- Daraus timestamp generieren, damit ich die date() - Funktion nutzen kann
Das sieht so aus:
[COLOR=red]$bruecke [/COLOR] = [COLOR=darkblue]split[/COLOR] ([COLOR=teal]"[/: ]"[/COLOR] , [COLOR=red]$a_pdate[/COLOR] );
[COLOR=red]$bruecke[0] [/COLOR] = check_month([COLOR=red]$bruecke[0] [/COLOR] );
[COLOR=red]$a_pdate[/COLOR] = = [COLOR=darkblue]date[/COLOR] ([COLOR=teal]"m/t/Y"[/COLOR],[COLOR=darkblue]mktime[/COLOR] (0,0,0,[COLOR=red]$bruecke[0] [/COLOR] ,[COLOR=red]$bruecke[1] [/COLOR] ,[COLOR=red]$bruecke[2] [/COLOR] ));
echo [COLOR=teal]"Datum: "[/COLOR] .[COLOR=red]$a_pdate[/COLOR] ;
Angezeigt wird aber immer nur der letzte Tag im Monat!
Monat stimmt, Jahr stimmt, Tag ist immer 30/31/28 (je nach Monat...)
Ausgabe Beispiel: Datum: 01/31/2002
Dann habe ich die Inhalte des Arrays Brücke geprüft:
Serviceidee Aktion Historie
aktuell: Jan 14 2002 12:00AM
Bruecke: Array ( [0] => 1 [1] => 14 [2] => 2002 [3] => 12 [4] => 00AM )
Also habe ich die Funktion mktime die Richtigen Werte eingegeben
int mktime ( int Stunde, int Minute, int Sekunde, int Monat, int Tag, int Jahr [, int is_dst])
Das einzige, was ich ändere ist die Uhrzeit. In meinem Programm zählt der Tag, die Uhrzeit ist irrelevant.
Ich hatte auch das mktime und die date - Funktionen getrennt und mir die Zwischenergebnisse ausgeben lassen.
Geändert hat dies nichts.
Ich bin morgen früh wieder am Arbeitsplatz und würde mich freuen, wenn mir jemand einen Rat geben kann.
Auch andere Lösungsvorschläge sind gern genommen!
Vielen Dank schon jetzt,
Lilith
Eigentlich mache ich innerhalb meines Programmes etwas sehr simples, warum dieser Fehler auftaucht, weiß ich nicht.
Aber von Anfang an:
PHP 4.3.0
Apache 1.3.26
Datenbank MS SQL 7.0
Ich lese aus der Datenbank ein Datum aus, dass ich anschliessend ausgeben möchte.
Da ich an mehreren Stellen im Programm Datumsausgaben habe, die aus verschiedenen Tabellen kommen, deren Datumsspalten unterschiedlich formatiert sind, sind natürlich aus die Ausgaben unterschiedlich.
Das sollte allerdings einheitlich sein. Info: Leider habe ich keine Möglichkeit, die Datumsformate auf DB Ebene zu ändern.
Folgendes wollte ich machen:
- Datum in Array splitten
- Monatsname durch Zahl ersetzen (Funktion check_month(Monat))
- Daraus timestamp generieren, damit ich die date() - Funktion nutzen kann
Das sieht so aus:
[COLOR=red]$bruecke [/COLOR] = [COLOR=darkblue]split[/COLOR] ([COLOR=teal]"[/: ]"[/COLOR] , [COLOR=red]$a_pdate[/COLOR] );
[COLOR=red]$bruecke[0] [/COLOR] = check_month([COLOR=red]$bruecke[0] [/COLOR] );
[COLOR=red]$a_pdate[/COLOR] = = [COLOR=darkblue]date[/COLOR] ([COLOR=teal]"m/t/Y"[/COLOR],[COLOR=darkblue]mktime[/COLOR] (0,0,0,[COLOR=red]$bruecke[0] [/COLOR] ,[COLOR=red]$bruecke[1] [/COLOR] ,[COLOR=red]$bruecke[2] [/COLOR] ));
echo [COLOR=teal]"Datum: "[/COLOR] .[COLOR=red]$a_pdate[/COLOR] ;
Angezeigt wird aber immer nur der letzte Tag im Monat!
Monat stimmt, Jahr stimmt, Tag ist immer 30/31/28 (je nach Monat...)
Ausgabe Beispiel: Datum: 01/31/2002
Dann habe ich die Inhalte des Arrays Brücke geprüft:
Serviceidee Aktion Historie
aktuell: Jan 14 2002 12:00AM
Bruecke: Array ( [0] => 1 [1] => 14 [2] => 2002 [3] => 12 [4] => 00AM )
Also habe ich die Funktion mktime die Richtigen Werte eingegeben
int mktime ( int Stunde, int Minute, int Sekunde, int Monat, int Tag, int Jahr [, int is_dst])
Das einzige, was ich ändere ist die Uhrzeit. In meinem Programm zählt der Tag, die Uhrzeit ist irrelevant.
Ich hatte auch das mktime und die date - Funktionen getrennt und mir die Zwischenergebnisse ausgeben lassen.
Geändert hat dies nichts.
Ich bin morgen früh wieder am Arbeitsplatz und würde mich freuen, wenn mir jemand einen Rat geben kann.
Auch andere Lösungsvorschläge sind gern genommen!
Vielen Dank schon jetzt,
Lilith
Kommentar