0

我有一个简单的函数转换datejava.sql.date.

public static java.sql.Date getSqlDate(String dateStr, String format) {
    java.sql.Date dt = null;
    Date date;
    SimpleDateFormat df = new SimpleDateFormat(format);
    ParsePosition pos = new ParsePosition(0);
    date = df.parse(dateStr, pos);
    Calendar cal = Calendar.getInstance();
    cal.setTime(date);
    dt = java.sql.Date.valueOf(cal.get(cal.YEAR) + "-" + (cal.get(cal.MONTH)+1)
            + "-" + cal.get(cal.DATE));
    return dt;
}

问题是当我使用以下命令调用此函数时,我得到一个IllegalArgumentException.

"2008-02-04", "yyyy-dd-MM"

可能是我无法在代码中发现错误,因此希望有另一双眼睛来调查这个问题并请纠正我......

-- 米

4

2 回答 2

2

尝试,

java.util.Date dt = null;
SimpleDateFormat df = new SimpleDateFormat(format);
ParsePosition pos = new ParsePosition(0);
date = df.parse(dateStr, pos);
java.sql.Date sqlDate = new java.sql.Date(date.getTime());
于 2012-07-02T12:26:48.290 回答
1

不应该是:

dt = java.sql.Date.valueOf(cal.get(cal.YEAR) + "-" + cal.get(cal.DATE)  + "-" +(cal.get(cal.MONTH)+1));

同意 yyyy-dd-mm 格式,因为您的代码示例显示 yyyy-mm-dd 格式:

cal.get(cal.YEAR) + "-" + (cal.get(cal.MONTH)+1) + "-" + cal.get(cal.DATE)
于 2012-07-02T12:17:53.313 回答