从 java.util.Date 转换为 java.sql.Date

kin*_*aeb 1 java sql oracle

我正在编写一个程序来为一群用户创建时间表。现在我有一个名为 AddTermineController 的控制器,它应该允许最终用户为另一个用户创建计划,以及计划的数据库连接类。当尝试保存时间表时,我收到此错误:

java.util.Date 无法转换为 java.sql.Date

这是我在其中创建语句的数据库类之外的:

public void addTermin(Termin terminXL) throws ParseException {
    try {

        PreparedStatement stat = con.prepareStatement(ADD_TERMIN);
        stat.setInt(1, terminXL.getUserID().getValue());
        stat.setString(2, terminXL.getUserNameT().getValue());
        stat.setString(3, terminXL.getKommentar().getValue());
        stat.setString(4, terminXL.getKategorie().getValue());
        //TODO von und bis in einen Datum umwandeln um es in die Datenbank einzuspeichern


        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("YYYY-MM-DD");
        Date datumVon = (Date) simpleDateFormat.parse(terminXL.getVon().getValue());
        Date datumBis = (Date) simpleDateFormat.parse(terminXL.getBis().getValue());

        stat.setDate(5, datumVon);
        stat.setDate(6, datumBis);
        stat.setString(6, terminXL.getBis().getValue());
        stat.setString(7, terminXL.getReferat().getValue());

        stat.executeUpdate();
        log.info("Neuer Termin angelegt");

    } catch (SQLException e) {
        e.printStackTrace();
    }

}
Run Code Online (Sandbox Code Playgroud)

这是我收到的错误代码:

线程“JavaFX 应用程序线程”java.lang.RuntimeException 中的异常:javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1774) 处的 java.lang.reflect.InitationTargetException 处 javafx.fxml.FXMLLoader$ControllerMethodEventHandler.handle(FXMLLoader) .java:1657) 在 com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86) 在 com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 在 com.sun.javafx。 event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 在 com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 在 com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)在com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)在com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)在com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent (EventDispatchChainImpl.java:114) 在 com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 在 com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 在 com.sun。 javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 在 com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49) 在 javafx.event.Event.fireEvent(Event.java:198) 在 javafx .scene.Node.fireEvent(Node.java:8413) 在 javafx.scene.control.Button.fire(Button.java:185) 在 com.sun.javafx.scene.control.behavior.ButtonBehavior.mouseReleased(ButtonBehavior.java :182)在com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorSkinBase.java:96)在com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorSkinBase.java:89) )在 com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218) 在 com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80) 在 com.sun.javafx.event。 EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 在 com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 在 com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 在 com .sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 在 com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 在 com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher) .java:56) 在 com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 在 com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 在 com.sun.javafx。 event.EventDispatchChainImpl。在 com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 在 com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54) 在 javafx.event 处调度事件(EventDispatchChainImpl.java:114) .Event.fireEvent(Event.java:198) 在 javafx.scene.Scene$MouseHandler.process(Scene.java:3757) 在 javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485) 在 javafx.scene .Scene.impl_processMouseEvent(Scene.java:1762) 在 javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:381 )在 com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295) 在 java.security.AccessController.doPrivileged(本机方法) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda $handleMouseEvent$354(GlassViewEventHandler.java:417) 在 com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java: 416) 在 com.sun.glass.ui.View.handleMouseEvent(View.java:555) 在 com.sun.glass.ui.View.notifyMouse(View.java:937) 在 com.sun.glass.ui.win .WinApplication._runLoop(本机方法)位于 com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)位于 java.lang.Thread.run(来源不明) 原因:java.lang在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)在sun.reflect.NativeMethodAccessorImpl.invoke(未知源)在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect.Method.invoke处.reflect.InitationTargetException (未知来源) 在sun.reflect.misc.Trampoline.invoke(未知来源) 在sun.reflect.GenerateMethodAccessor2.invoke(未知来源) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源) 在java.lang.reflect.Method .invoke(未知来源) at sun.reflect.misc.MethodUtil.invoke(未知来源) at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769) ... 48 更多 造成者:java.lang.ClassCastException : java.util.Date 无法在 de.dpma.azubidpma.dao.TerminDAO.addTermin(TerminDAO.java:82) 处转换​​为 java.sql.Date 在 de.dpma.azubidpma.view.AddTermineController.saveButton(AddTermineController.java :79) ... 58 更多381) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295) 在 java.security.AccessController.doPrivileged(本机方法) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler。 lambda$handleMouseEvent$354(GlassViewEventHandler.java:417) 在 com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java :416)在com.sun.glass.ui.View.handleMouseEvent(View.java:555)在com.sun.glass.ui.View.notifyMouse(View.java:937)在com.sun.glass.ui。 win.WinApplication._runLoop(本机方法)位于 com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)位于 java.lang.Thread.run(来源不明) 原因:java.lang.在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处的lang.reflect.InitationTargetException 在sun.reflect.NativeMethodAccessorImpl.invoke(未知源)处 在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)处 在java.lang.reflect.Method处。在sun.reflect.misc.Trampoline.invoke(未知源)在sun.reflect.GenerateMethodAccessor2.invoke(未知源)在sun.reflect.Misc.Trampoline.invoke(未知源)在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect。 Method.invoke(未知来源) at sun.reflect.misc.MethodUtil.invoke(未知来源) at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769) ... 48 更多 造成者:java.lang。 ClassCastException: java.util.Date 无法在 de.dpma.azubidpma.dao.TerminDAO.addTermin(TerminDAO.java:82) 处转换​​为 java.sql.Date 在 de.dpma.azubidpma.view.AddTermineController.saveButton(AddTermineController.爪哇:79) ... 58 更多381) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295) 在 java.security.AccessController.doPrivileged(本机方法) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler。 lambda$handleMouseEvent$354(GlassViewEventHandler.java:417) 在 com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) 在 com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java :416)在com.sun.glass.ui.View.handleMouseEvent(View.java:555)在com.sun.glass.ui.View.notifyMouse(View.java:937)在com.sun.glass.ui。 win.WinApplication._runLoop(本机方法)位于 com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191)位于 java.lang.Thread.run(来源不明) 原因:java.lang.在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处的lang.reflect.InitationTargetException 在sun.reflect.NativeMethodAccessorImpl.invoke(未知源)处 在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)处 在java.lang.reflect.Method处。在sun.reflect.misc.Trampoline.invoke(未知源)在sun.reflect.GenerateMethodAccessor2.invoke(未知源)在sun.reflect.Misc.Trampoline.invoke(未知源)在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect。 Method.invoke(未知来源) at sun.reflect.misc.MethodUtil.invoke(未知来源) at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769) ... 48 更多 造成者:java.lang。 ClassCastException: java.util.Date 无法在 de.dpma.azubidpma.dao.TerminDAO.addTermin(TerminDAO.java:82) 处转换​​为 java.sql.Date 在 de.dpma.azubidpma.view.AddTermineController.saveButton(AddTermineController.爪哇:79) ... 58 更多在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect.Method.invoke(未知源)在sun.reflect.misc.MethodUtil.invoke(未知源)在reflect.GenerateMethodAccessor2.invoke(未知源) javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769) ... 48 更多 原因:java.lang.ClassCastException: java.util.Date 无法在 de.dpma.azubidpma 处转换为 java.sql.Date .dao.TerminDAO.addTermin(TerminDAO.java:82) 在 de.dpma.azubidpma.view.AddTermineController.saveButton(AddTermineController.java:79) ... 58 更多在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect.Method.invoke(未知源)在sun.reflect.misc.MethodUtil.invoke(未知源)在reflect.GenerateMethodAccessor2.invoke(未知源) javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769) ... 48 更多 原因:java.lang.ClassCastException: java.util.Date 无法在 de.dpma.azubidpma 处转换为 java.sql.Date .dao.TerminDAO.addTermin(TerminDAO.java:82) 在 de.dpma.azubidpma.view.AddTermineController.saveButton(AddTermineController.java:79) ... 58 更多

如果您需要任何其他代码括号,请告诉我,我会尽快更新这篇文章。

Jav*_*er1 5

java.util.Date d = new java.util.Date();
java.sql.Date sd = new java.sql.Date(d.getTime());
Run Code Online (Sandbox Code Playgroud)