[踩过的坑] 从数据库读出来的日期后面多了个 .0

本文解决Java从数据库读取的timestamp类型日期显示多余小数点的问题,通过SimpleDateFormat进行格式化,展示如何将时间戳转换为标准日期时间格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

情景

用java 代码从数据库中获取某时间字段,显示的内容多了一个零。如:数据库中是2019-6-1 12:05:54,java读取出来为2019-6-1 12:05:54.0
那么问题来了,该如何将这个字段显示为正常的时间格式呢?以及java为什么读取出来会多一个零呢?

原因

原因是数据库中改字段是 datatime类型,使用java读取该字段时对应的类型为timestamp类型日期。

解决方案:

清单一:时间转换

String endAt= map.get("endAt").toString()    // 这个是从数据库读取出来的,debugger时,可以看到是timestamp类型

SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")

Date date = simpleDateFormat.parse(endAt)
String endAtStr = simpleDateFormat.format(date)

println("endAt[原本从数据库读出来的 timestamp 类型日期] : " + endAt); 
println("date.toLocaleString() [打印Data.toLocaleString()]: " + date.toLocaleString()); 
println("fmt.format(date) : " + endAtStr ); 

运行结果:

 endAt[原本从数据库读出来的 timestamp 类型日期] : 2019-05-02 23:59:59.0
 date.toLocaleString() [打印Data.toLocaleString()]: 2019-5-2 23:59:59
 fmt.format(date) : 2019-05-02 23:59:59
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值