传入的是一个格式为:2018/12/06 12:30的字符串,在用
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd hh:mm")
对字符串进行日期格式转换后,
sdf.parse("2018/12/06 12:30")
发现原来的12:30到了数据库里变成了00:30
但是同一批次处理的数据并没有发生格式转换错误或者数据错误。
那这就很尴尬了,是什么原因导致这种情况发生呢。
最后,头皮都挠破了,发现把
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd hh:mm")
改为:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm")
就好了
注意,代表小时的HH是大写的,大写的,由小写h改为了大写H。
但是百度之后,
大写的H代表的是24小时制,那么发生这个错误情有可原,但是小写的h在处理数据的时候为什么会将14、16这些类型的小时格式成功转换呢?
还请大神告知!