近日工作中遇到一问题,由于代码不严谨,导致测试时发现业务处理时的日期与所选日期相差三个月,故在此记录。
我们都知道在oracle中时间格式,yyyy-mm-dd 和yyyy-MM-dd 效果是一样的,但是在java代码中却是不一样的,
举个例子:
将字符串转化成日期
将"2014-09-30"String 类型 转换成Date类型
java代码
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class Test {
public static void main(String[] args) {
DateFormat dd = new SimpleDateFormat("yyyy-mm-dd");
try {
Date da = dd.parse("2014-09-30");
System.out.println(da);
} catch (ParseException e) {
e.printStackTrace();
}
}
}
运行结果为:
Thu Jan 30 00:09:00 CST 2014 : 是1月,0点09分,说明把9月当成了分钟来处理.
出现这样的原因是java中时间格式MM和mm是不一样的.需要将yyyy-mm-dd改成yyyy-MM-dd
代码应该改成
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class Test {
public static void main(String[] args) {
DateFormat dd = new SimpleDateFormat("yyyy-MM-dd");
try {
Date da = dd.parse("2014-09-30");
System.out.println(da);
} catch (ParseException e) {
e.printStackTrace();
}
}
}
运行结果:
Tue Sep 30 00:00:00 CST 2014
另附标准定义表
字母 日期或时间元素 表示 示例
G | Era 标志符 | Text | AD |
y | 年 | Year | 1996 ; 96 |
M | 年中的月份 | Month | July ; Jul ; 07 |
w | 年中的周数 | Number | 27 |
W | 月份中的周数 | Number | 2 |
D | 年中的天数 | Number | 189 |
d | 月份中的天数 | Number | 10 |
F | 月份中的星期 | Number | 2 |
E | 星期中的天数 | Text | Tuesday ; Tue |
a | Am/pm 标记 | Text | PM |
H | 一天中的小时数(0-23) | Number | 0 |
k | 一天中的小时数(1-24) | Number | 24 |
K | am/pm 中的小时数(0-11) | Number | 0 |
h | am/pm 中的小时数(1-12) | Number | 12 |
m | 小时中的分钟数 | Number | 30 |
s | 分钟中的秒数 | Number | 55 |
S | 毫秒数 | Number | 978 |
z | 时区 | General time zone | Pacific Standard Time ; PST ; GMT-08:00 |
Z | 时区 | RFC 822 time zone | -0800 |