java - hibernate - 将日期从一种格式转换为另一种格式

时间:2015-02-22 14:48:46

标签: java mysql hibernate date datetime

我正在尝试将日期从一种格式转换为另一种格式,输入的日期采用以下格式:'mm-dd-yyyy'到'yyyy-mm-dd'。

我以“mm-dd-yyyy”格式从网页收到日期,当我使用hibernate在mysql中插入此日期时,日期会更改为某个匿名值。

请帮忙!!! {

import java.io.*;
import java.text.*;
import java.util.*;

class test{
public static void main(String...s)throws Exception{
Date date ;
String datestr;
DateFormat dateFormat1 = new SimpleDateFormat("mm-dd-yyyy");
DateFormat dateFormat2 = new SimpleDateFormat("yyyy-mm-dd");

date = dateFormat1.parse("01-01-2015");
datestr = dateFormat1.format(date);

System.out.println(date);
System.out.println(datestr);

date = dateFormat2.parse(datestr);
datestr = dateFormat2.format(date);

System.out.println(date);
System.out.println(datestr);
}
}

4 个答案:

答案 0 :(得分:2)

你可以这样试试;

        DateFormat originalFormat = new SimpleDateFormat("MM-dd-yyyy", Locale.ENGLISH);
        DateFormat targetFormat = new SimpleDateFormat("yyyy-MM-dd");
        Date date = originalFormat.parse("01-21-2013");
        String formattedDate = targetFormat.format(date); 
        System.out.println(formattedDate);

对于日期类型结果;

    DateFormat originalFormat = new SimpleDateFormat("mm-dd-yyyy", Locale.ENGLISH);
    DateFormat targetFormat = new SimpleDateFormat("yyyy-mm-dd");
    Date date = originalFormat.parse("01-21-2013");
    String formattedDate = targetFormat.format(date); 
    java.util.Date dtt = targetFormat.parse(formattedDate);
    java.sql.Date ds = new java.sql.Date(dtt.getTime());
    System.out.println(ds);
    System.out.println(dtt);
    System.out.println(formattedDate);

结束输出;

2013-01-21
Mon Jan 21 00:01:00 EET 2013
2013-01-21

答案 1 :(得分:0)

您可以使用以下代码段

 public static String formatDate (String date, String initDateFormat, String endDateFormat) throws ParseException {

    Date initDate = new SimpleDateFormat(initDateFormat).parse(date);
    SimpleDateFormat formatter = new SimpleDateFormat(endDateFormat);
    String parsedDate = formatter.format(initDate);

    return parsedDate;
}

答案 2 :(得分:0)

Date initDate = new SimpleDateFormat("yyyy-MM-dd").parse("2015-03-05");
System.out.println("initDate == "+initDate);

输出==>> initDate == 2015年3月5日00:00:00 ICT 2015

答案 3 :(得分:0)

在HQL中简单的SQL函数工作:

DATE_FORMAT(DATE,'%d-%m-%Y')