String aus JTextField in Datum umwandeln

Status
Nicht offen für weitere Antworten.
Z

Ziza

Gast
Hallo,

ich möchte das mein Programm folgendes kann:

Ein Datum wird in ein TextFeld eingegeben und anschließend mit Feld.getText() ausgelesen. Dann soll dieses Datum im where Konstrukt einer sql-Anweisung mit einem Datum verglichen werden, dass ich aus einer Datenbanktabelle auslese.

Dabei habe ich mehrere Probleme:

1. Das Datum ist in der Tabelle im Format '0000-00-00 00:00:00' gespeichert. Da mich aber eigentlich nur das Datum und nicht die Uhrzeit interessiert schneide ich den String mit substring(timestamp,1,10) ab.

2. Ich habe versucht mit JFormattedTextField über MaskFormatter die Eingabe in meinem Textfeld vorzugeben, dass ich dann nur beide Daten vergleichen müsste. Das hat aber schon mal nicht geklappt.

Naja also ich weiß nicht wirklich wie ich es hinkriegen kann, dass mein String aus dem TextFeld mit dem String aus der Tabelle verglichen werden kann.

Kann ich vielleicht beide Strings in Zahlen umwandeln? bzw. in diese timestamp Notation, die das Datum in Sekunden angibt? Dann wäre es doch gar nicht nötig, dass ich das Datum aus der Tabelle abschneide, oder?


Danke schon mal für jegliche Hilfe
Gruß Ziza
 

L-ectron-X

Gesperrter Benutzer
Du kannst den benötigten Teil des timestamps (also '0000-00-00') in ein long parsen.
Code:
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
Date date = formatter.parse(timestamp);
long inMillis = date.getTime();
 
Z

Ziza

Gast
aber das geht ja irgendwie nicht, weil ich den timestamp ja nur in der SQL - Anweisung benutze und da kann ich ja schlecht mit formatter.parse(timestamp) reinschreiben.

Hier ist mal der Select, den ich machen möchte:

Code:
String sqlselect_sessions = "select session_id 
                                         from tabelle
                                         where substring(timestamp,1,10) > '"+ datumVon +"'
                                         and substring(timestamp,1,10) < '"+ datumBis +"'
                                         LIMIT 0,"+ anz +";";

Ich möchte also "anz" viele session_id's von einem Datum (das ich ins Textfeld eingebe) bis zu einem anderen Datum (das ich auch ins Textfeld eingebe) auslesen.

Hmm, aber könnte ich mit dem formatter vielleicht meine Eingabe ins Textfeld parsen. Funktioniert das mit einem string, wenn er auch in der Art 0000-00-00 angegeben ist?
Und wenn das geht, kann ich dann auch dieses Datum direkt mit dem aus der Tabelle vergleichen?

Gruß Ziza
 
Z

Ziza

Gast
ich hab jetzt nochmal drüber nachgedacht und eigentlich müsste es doch funktionieren, wenn ich das Datum
aus der Tabelle als Datum lasse und dann mit dem Datum, dass in meinem TextFeld eingegeben wird vergleiche.

Das habe ich auch schon versucht zu lösen, aber jetzt bekomme ich eine Fehlermeldung mit der ich nichts anfangen kann.


also hier erstmal die Codeausschnitte die für das Textfeld relevant sind:

Code:
JFormattedTextField VonField;
...
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
VonField = new JFormattedTextField(formatter);

...

Date von = (Date)VonField.getValue();

Ich habe mein Datum dann auch so in das TextFeld eingegeben: 2005-03-20
Ist das vielleicht falsch? Oder setzt der das Datum irgendwie anders um?

Hier nochmal die Fehlermeldung:

Code:
Exception in thread "AWT-EventQueue-0" java.lang.ClassCastException: java.util.Date
	at GuiCardLayout.actionPerformed(GuiCardLayout.java:600)
	at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1849)
	at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2169)
	at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:420)
	at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:258)
	at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:234)
	at java.awt.Component.processMouseEvent(Component.java:5488)
	at javax.swing.JComponent.processMouseEvent(JComponent.java:3126)
	at java.awt.Component.processEvent(Component.java:5253)
	at java.awt.Container.processEvent(Container.java:1966)
	at java.awt.Component.dispatchEventImpl(Component.java:3955)
	at java.awt.Container.dispatchEventImpl(Container.java:2024)
	at java.awt.Component.dispatchEvent(Component.java:3803)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4212)
	at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3892)
	at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3822)
	at java.awt.Container.dispatchEventImpl(Container.java:2010)
	at java.awt.Window.dispatchEventImpl(Window.java:1774)
	at java.awt.Component.dispatchEvent(Component.java:3803)
	at java.awt.EventQueue.dispatchEvent(EventQueue.java:463)
	at java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.java:242)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:163)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:157)
	at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:149)
	at java.awt.EventDispatchThread.run(EventDispatchThread.java:110)


Gruß Ziza
 

PoiSoN

Bekanntes Mitglied
Hallo,
statt einfach zu casten ("Date von = (Date)VonField.getValue();") musst du ein ganz neues
Objekt vom Typ Date erzeugen... java.util.Date von = new java.util.Date(...);
Meine mich zumindest daran erinnern zu können, das mal so gemacht zu haben. Probiers mal aus...
 
Z

Ziza

Gast
hmm... aber wie genau muss ich dass dann schreiben?

so scheints nicht zu funktionieren:

Code:
java.util.Date von = new java.util.Date(VonField.getValue());

da kommt dann die Meldung: The constructor Date(Object) is undefined

Muss ich dann die Datumsteile einzeln auslesen und als integer übergeben? Und wenn ja wie würde das gehen?
 
R

Roar

Gast
oh mann...
es würde schon reichen, wenn du deine imports selbst tippen würdest, dann würde sowas auch nicht passieren *mitdemzaunpfahlwink*
 

PoiSoN

Bekanntes Mitglied
Ob man nun java.util.* importiert und dann schreibt Date bla = new Date(...)
oder ob man's nicht importiert und schreibt java.util.Date bla = new java.util.Date(...):
die Exception wird so oder so geworfen, wenn das falsche an den Konstruktor übergeben
wird... Oder reden wir jetzt irgendwie aneinander vorbei?
???:L
 

PoiSoN

Bekanntes Mitglied
Öh... ALLES?
"The constructor Date(Object) is undefined" bedeutet, dass der Konstruktor etwas anderes als Object erwartet.
 
R

Roar

Gast
PoiSoN hat gesagt.:
Öh... ALLES?
"The constructor Date(Object) is undefined" bedeutet, dass der Konstruktor etwas anderes als Object erwartet.
das ist keine exception :?
ich rede von der exception:
Code:
Exception in thread "AWT-EventQueue-0" java.lang.ClassCastException: java.util.Date
   at GuiCardLayout.actionPerformed(GuiCardLayout.java:600)
 
R

Roar

Gast
PoiSoN hat gesagt.:
Und? Die ist aufgetreten, weil einfach gecastet wurde, was hat das mit den imports zu tun?
wieso, der cast ist doch theoretisch richtig.

<kristallkugel>er hat eclipse, drückt ctrl+shift+o, drückt enter um das*störende* fensterchen wegzumachen was ja eh keine bedeutung hat und wundert sich dass nix klappt. leider steht bei eclipse in der auswahlliste bei den import java.sql.Date als oberstes in der liste, und das wird importiert, darum klappt sein cast nicht und darum soll er seine imports selber schreiben oder gucken was er automatisch importieren lässt :x</kristallkugel>
 
Z

Ziza

Gast
hallo :)

also erstmal bin ich eine "sie".

Ja um die imports hab ich mich wirklich nicht sehr gekümmert, weil eclipse die eben so schön selber reingemacht hat.

Jetzt hab ich java.util.Date also importiert. Ich habe aber auch sun.util.calendar.BaseCalendar.Date importiert und das scheint irgendwie damit nicht zusammenzupassen, kann das sein?

Und wenn ich das rausmache, dann kommt auch wieder die Fehlermeldung mit constructor Date(object).

Wisst ihr jetzt ne Lösung?
 
R

Roar

Gast
ups :)

Code:
import java.util.Date; // und sonst kein Date

Date d = (Date) bla.getValue();

und schon gehts
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Input/Output JTextField Eingabe in String Variable speichern Java Basics - Anfänger-Themen 15
F Variablen JTextField-Inhalt kann nicht mit String abgeglichen werden Java Basics - Anfänger-Themen 2
B Interface JTextField Eingabe als String verwenden Java Basics - Anfänger-Themen 3
P Datentypen String auf JTextField wird zu Char-Array und anschließend zu int Java Basics - Anfänger-Themen 12
K String in JTextfield formatiert ausgaben Java Basics - Anfänger-Themen 5
G zwei Zahlen bei String.valueOf(char c) in JTextField Java Basics - Anfänger-Themen 7
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
Poppigescorn String mit mehreren Wörtern füllen? Java Basics - Anfänger-Themen 4
I String Expression mit Java validieren (true / false) Java Basics - Anfänger-Themen 34
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
T Maximale Anzahl von Konsonanten im String Java Basics - Anfänger-Themen 6
H String verschlüsseln - eigener Algorithmus Java Basics - Anfänger-Themen 104
N Aus einem String die Anzahl der Vokale auslesen Java Basics - Anfänger-Themen 40
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
K mit String.splitt(",") ganzen Satz erhalten? Java Basics - Anfänger-Themen 3
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben