发现奇怪的现象,前端调用update接口的时候,传了一个时间戳(2664180000)给接口,接口会保存这个时间到msql。但是当前端调查询接口时,返回的这个字段变成了一个负数(-14220000)
去看了下接口,update接口,时间是Date类型,查询接口也是Date类型。想想那应该问题出在数据库了,查看数据库发现类型存的是time,原来这就是问题所在了。
数据库里存的是time类型,调update接口时,不管传的是哪一年,数据库里面是不保存年月日的,只保存小时:分钟:秒。
查询的时候java里的类型又是Date, 会自动转成1970/01/01 这天, 而我们是北京时间东8区(在北京时间,1970/01/01 08:00:00的时间戳为0),所以只要时间小于8点的,查出来都会变成负数