如何将JTextField字符串转换为java.sql.date日期

问题描述:

一个常见问题(也适用于我)是:如何将一个简单的String从例如将JTextField改为java.sql.dateDate - 通过准备好的声明将一些GUI用户输入作为正确格式化的日期插入表中。如何将JTextField字符串转换为java.sql.date日期

我会写一个新的convert-specified Class,它有这个选项。

import java.text.SimpleDateFormat; 
import java.util.Date; 


public class convertText { 
    public java.sql.Date formatStringToSQLDate(String strDate) throws Exception{ 
     Date utilDate = new Date(); //DateFormat 
     SimpleDateFormat dfFormat = new SimpleDateFormat("dd.MM.yyyy"); // parse string into a DATE format  
     utilDate = dfFormat.parse(strDate); // convert a util.Date to milliseconds via its getTime() method   
     long time = utilDate.getTime(); // get the long value of java.sql.Date 
     java.sql.Date sqlDate = new java.sql.Date(time); 
     return sqlDate; 
    } 
} 

然后,就像这样使用它。

Connection dp = DriverManager.getConnection("jdbc:ucanaccess://" + Filepath + Filename); 
Statement stat = dp.createStatement(); 
String sql = "INSERT INTO user_table (Name, Birth) VALUES(?, ?)"; //statement as string 
PreparedStatement pstmt = dp.prepareStatement(sql); 
pstmt.setString(1, textFieldVorname.getText()); //replaces the first '?' 
pstmt.setDate(2, Date.formatStringToSQLDate(textFieldGeburtsdatum.getText())); //replaces the second '?' 
pstmt.executeUpdate(); //executes the insert-query