我已经使用Calendar类来获取当前的Date.现在,我想将该日期转换为日期格式,以便可以将其以“ 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);
}
}
最佳答案
我运行了您的代码,并得到了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.这很重要.