转换为SqlDate后输出不正确

时间:2016-04-25 05:33:36

标签: java sql oracle

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


public class Test {

    /**
     * @param args
     */
    public static void main(String[] args) {
        SimpleDateFormat formatter = new SimpleDateFormat("yyyy-mm-dd");
        String dateInString = "2016-04-23";

        try {

            Date date = formatter.parse(dateInString);
            java.sql.Date sqlDate = new java.sql.Date(date.getTime());
            System.out.println("Date: -- "+date);
            System.out.println("FormatterDate : -- "+formatter.format(date));
            System.out.println("SQLDATE : -- "+sqlDate);
        } catch (ParseException e) {
            e.printStackTrace();
        }

    }

}

输出:

Date: -- Sat Jan 23 00:04:00 CST 2016
FormatterDate : -- 2016-04-23
SQLDATE : -- 2016-01-23

我的出局应该是2016-04-23而不是2016-01-23

2 个答案:

答案 0 :(得分:1)

请注意mm代表分钟而非月份。对于月份,您必须改为使用WITH-LOCK-HELD

答案 1 :(得分:1)

根据javadocs

m   Minute in hour

你想要

M   Month in year