3

我已经使用日历类来获取当前日期。现在我想将该日期转换为日期格式,以便它可以以“yyyy-mm-dd”格式存储在数据库中。我尝试使用 SimpleDate 格式对其进行转换,但出现错误。代码如下。帮助。提前致谢。

class dateDemo
{
    public static void main(String args[])
    {


    String stringdate ;
    SimpleDateFormat sdf;
    String year,month,day;  

    Calendar currentDate;
    Date validity;

    currentDate = Calendar.getInstance();

    year = "" + currentDate.get( Calendar.YEAR );
    month = "" + currentDate.get( Calendar.MONTH );
    day = "" + currentDate.get( Calendar.DAY_OF_MONTH );


    stringdate = year+"/"+month+"/"+day;


    sdf = new SimpleDateFormat("yyyy-mm-dd");

    try
    {
    validity = sdf.parse ( stringdate );
    }

     catch(Exception e)
    {
            System.out.println(""+e);
    }

    System.out.println("Current Date is:"+stringdate);


    System.out.println("Date is"+validity);             

    }
}
4

3 回答 3

2

我运行了你的代码并得到了java.text.ParseException. 只是为了消除错误,您可以简单地将程序中的“/”更改为“-”,但它不会为您提供正确的日期。

试试这个修改后的解决方案,采用 String、java.util.Date 和 java.sql.Date 格式:

class dateDemo {

    public static void main(String args[]) {

        SimpleDateFormat sdf;
        String validity = "";
        Date validityDate = null;
        java.sql.Date validateDateSql = null;

        Date currentDate = Calendar.getInstance().getTime();
        sdf = new SimpleDateFormat("yyyy-MM-dd");
        try {
            validity = sdf.format(currentDate);
            validityDate = sdf.parse(validity);
            validateDateSql = new java.sql.Date(validityDate.getTime());                    
        } catch (Exception e) {
            System.out.println("" + e);
        }
    }
}

记下 SimpleDateFormat 设置:yyyy-MM-dd,而不是yyyy-mm-dd。这很重要。

于 2013-04-20T12:59:12.883 回答
1

阅读 Roxinus 的答案以获取正确的代码。

我建议您在编写代码时始终查看 Java API 的文档。它非常有用,您经常会发现如何使用该代码: Java API 文档

于 2013-04-20T13:31:49.517 回答
1

数据库连接器可以处理日期,不要将其转换为字符串,这不是一个好习惯。

您可以像这样重写代码:

PreparedStatement pstmt = connection.prepareStatement("INSERT INTO MyTable values(?)");
java.sql.Date sqlDate = new java.sql.Date(currentDate.getTime()); 
pstmt.setDate(1, sqlDate)
于 2013-04-20T13:53:46.097 回答