Probleme mit der String-Prüfung

Status
Nicht offen für weitere Antworten.

Alex_winf01

Top Contributor
Ich habe einen String, der wie folgt aussehen kann:

1) 25.1.2005 oder
2) 25.01.2005

Nun muss ich prüfen, ob dieser String < als der 1.1.2008 ist. Wie kann ich das machen?
 

The_S

Top Contributor
Code:
String[] temp = "25.1.2005".split("\\.");
if (Integer.parseInt(temp[2]) < 2008) {
   // vor dem 1.1.2008
}
 
G

Guest

Gast
angenommen, der Anwender gibt den 25.1.08 ein, wie müsste es dann aussehen?
 
G

Gast

Gast
@alex datumsprüfungen gehen ganz einfahc mit gregoriancalendar.

zb.

Code:
GregorianCalendar von = new GregorianCalendar(2005,0,25);
GregorianCalendar bis = new GregorianCalendar(2008,0,1);

if(von.before(bis))//wenn von-Datum vor bis-Datum dann....
{
//Hier Anweisungsblock
}

Hinweis: Monate beginngen mit 0. ist aber der Januar
 
G

Gast

Gast
du kannst das ganze auch varieren! z.b prüfen mit equals, before, after....
 

The_S

Top Contributor
ja und? Wenn ich wissen will, ob ein Datum vor oder nach dem/bzw. am 1.1. eines beliebigen Jahres liegt, dann muss ich doch auch nur das Jahr überprüfen. Alles andere ist überflüssig.
 
G

Gast

Gast
nichts und :) , es hatte nur den Anschein als ob der User erst das jahr per String prüfen will, dann monat und dann tag, und das es keine bequeme lösung.
 

Alex_winf01

Top Contributor
Ich will doch nur überprüfen, ob ein bestimmtes Datum VOR dem 1.1.2008 liegt.

@ Hobbit_Im_Blutrausch

Wenn der Anwender jetzt den 25.1.08 eingegeben hat, wie muss ich dann
Code:
if (Integer.parseInt(temp[2]) < 2008)
anpassen? Bleibt es dann bei
Code:
Integer.parseInt(temp[2])
? Dass ich dann statt 2008 8 schreiben muss, ist mir klar.
 

The_S

Top Contributor
natürlich bleibt es dann bei "temp[2]".

Sowas wäre z. B. auch möglich:

Code:
String datum = "25.1.08";
String year = datum.substring(datum.lastIndexOf(".") + 1);
if ((year.length() < 4 && Integer.parseInt(year) < 8) ||
    (year.length() > 3 && Integer.parseInt(year) < 2008)) {
   // vor dem 1.1.2008
}
 

Alex_winf01

Top Contributor
Vielleicht bin ich auch etwas übermüdet, habe aber folgendes "Problem":

Code:
/*-------------------------------------------------------------------*/
		/**J L i s t */
		/*-------------------------------------------------------------------*/
		liste_export = new JList(defaultlistmodel_export);
		liste_export.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
		liste_export.setSelectedIndex(0);
		liste_export.setSize(50,50);
		export_scrollPane = new JScrollPane(liste_export);
		export_scrollPane.setViewportView(liste_export);
		p.add(export_scrollPane);

String query_export = "SELECT nummer, anzahl, datum FROM tabelle where status = 'offen' ";
Statement export_st = Login.connection.createStatement();// Statement erzeugen
ResultSet export_rs = export_st.executeQuery(query_export);// Query ausführen[/code]

Wie bekomme ich das jetzt in die SELECT-Anweisung, dass ich mir nur die Datensätze anzeigen lasse, wo das Datum vor dem 1.1.2008 liegt?
 

The_S

Top Contributor
Mal ganz davon abgesehen, dass du nicht erwähnt hast, dass es sich um SQL dreht, und dein Code ... nunja ... rein gar nichts mit dem Problem zu tun hat:

Ihr speichert nicht wirklich ein Datum als CHAR/VARCHAR und auch noch in unterschiedlichen Formaten in eine DB :shock:!? Um welches DBMS geht es denn?
 
G

Guest

Gast
Eigentlich war es Vorgabe vom Kunden einen char zu nehmen und ja, der Anwender ist es einfach gewohnt z. B. 1.1.2007 einzugeben oder halt 01.01.2007.

Ich verwende die H2-Datenbank. Ich kann auch Date nehmen, das hat dann das Format 2004-12-31. Wie kann ich das denn jetzt prüfen, ob dieses Format vor dem 1.1.2008 liegt?
 

The_S

Top Contributor
Schreib die Daten in einem einheitlichen Format in deine DB. Am besten sowas yyyyMMdd oder yyyy.MM.dd. Dann kannst du bei deiner Kundenvorgabe (speichern als Char) bleiben. Kannst du das mal eben so ändern? Weil ansonsten würde der SQL ein ziemliches gewurstel werden.

Wenn der Anwender es gewohnt ist das Datum nach Belieben einzugeben, und du ihm das erlaubst, dann ist es Aufgabe des Programmieres dafür zu sorgen, dass das Datum in einem einheitlichen Format umgewandelt und abgespeichert wird. Dabei könnte die die Klasse DateFormat bzw. SimpleDateFormat helfen.
 

Alex_winf01

Top Contributor
@ Hobbit_Im_Blutrausch

Danke schon mal für Deine Antwort. Wie bekomme ich jetzt diesen Teil

Code:
String[] temp = "25.1.2005".split("\\.");
if (Integer.parseInt(temp[2]) < 2008) {
   // vor dem 1.1.2008
}

in die Select-Anweisung?

Es muss dann ja so aussehen:
Code:
select * from tabelle where datum =
und dann halt alles < 2008
 

The_S

Top Contributor
Magst du vorher auf meinen letzten Posting auf der vorhergehenden Seite eingehen!? Wenn du ein Datum in einem x-beliebigen Format als CHAR abspeicherst, ist deine Abfrage nach wie vor nicht so einfach. Ich hab auch kA, ob der H2-Dialekt so Dinge wie Substring, lastIndexOf und case when zur Verfügung stellt.
 

Alex_winf01

Top Contributor
Also ok, überzeugt. Gleiches Format. Die H2-Datenbank bietet mir die Funktion RIGHT an mit folgender Syntax:
Code:
RIGHT(string, int): string

Beispiel:

Code:
RIGHT(NAME,3)

Wäre das vielleicht eine Lösung? Und wie müsste das dann aussehen?
 

The_S

Top Contributor
Wenn du das gleiche Format hast (z. B. yyyyMMdd), dann ergänze einfach deine WHERE-Klausel um das hier:

Code:
AND datum < '20080101'
 
G

Guest

Gast
Das Format wäre dann wie folgt:

01.01.2008. Dann kann ich doch nicht sagen datum <
Code:
'20080101'
 

The_S

Top Contributor
Is es denn so schwer zu verstehen ein Datum in einem "normalen" Format abzuspeichern? Entweder als "DATE", oder eben yyyyMMdd (wenns sein muss mit beliebigen Trennzeichen). Ansonsten ist das alles gepfuscht ...

Du müsstest dann in der Where-Klausel dein Datum umdrehen. Also sowas in der Art (kenn die H2-Syntax nicht):

Code:
AND CONCAT(CONCAT(SUBSTR(datum, 7, 4), SUBSTR(datum, 4, 2)), SUBSTR(datum, 1, 2)) < '20080101'
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Probleme mit String in Label übergeben. Allgemeine Java-Themen 6
P Datei in einen String lesen Probleme bei Codierung Allgemeine Java-Themen 2
M String#equals(), Probleme mit großen Strings? Allgemeine Java-Themen 4
G Probleme bei String Übergabe um Public Key zu erzeugen ? Allgemeine Java-Themen 6
V Probleme mit String.Split :/ Allgemeine Java-Themen 2
A Probleme Umwandlung Ausdruck String in double Allgemeine Java-Themen 4
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0
R DBUnit Performance Probleme Allgemeine Java-Themen 0
S Probleme mit Collection Allgemeine Java-Themen 7
L Probleme mit Jar Allgemeine Java-Themen 6
N Zahlensysteme umrechnen; Probleme beim Umwandeln Allgemeine Java-Themen 4
K OOP OOP Gui Spiel + Vererbungen Probleme durch Nichtwissen!! Allgemeine Java-Themen 1
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Synchronized Probleme Allgemeine Java-Themen 7
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit dem filechooser Allgemeine Java-Themen 1
J Comperator Probleme Allgemeine Java-Themen 4
A Probleme beim auslesen von Quelltext (HTML) Allgemeine Java-Themen 5
S Probleme mit Webappplikation Allgemeine Java-Themen 5
L Plötzlich Probleme mit der JVM :( Allgemeine Java-Themen 6
S starke performance probleme des forums Allgemeine Java-Themen 10
K Probleme bei Berechnung der Komplexität Allgemeine Java-Themen 7
R JRE Ablaufdatum seit 7u10 - Probleme bei selbst ausgelieferter JRE bekannt? Allgemeine Java-Themen 3
H Reg Exp Probleme Allgemeine Java-Themen 5
M Classpath Probleme bei JAR Generierung Allgemeine Java-Themen 2
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
D Probleme bei for-Schleife Allgemeine Java-Themen 4
R Probleme mit Javadoc Allgemeine Java-Themen 2
G Gson Probleme Allgemeine Java-Themen 2
P KI für TicTacToe programmieren > Probleme Allgemeine Java-Themen 2
M Google App Engine macht Probleme Allgemeine Java-Themen 4
H Probleme mit finally-Block und close() Allgemeine Java-Themen 4
F 2d array probleme Allgemeine Java-Themen 2
M 3D-Grafik Probleme beim drehen von Objekten Allgemeine Java-Themen 9

Ähnliche Java Themen

Neue Themen


Oben