暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

GBase 8a 使用 JDBC 对时间按照获取时间的时区格式化

原创 王海 2022-09-29
265

问题
我们现在支持的 oracle、sqlserver、sybaseiq 等数据库获取时间的处理,按什么时 区获取时间就按什么时区格式化时间(例如按 gmt0 时区获取时间就按 gmt0 时区 格式化),出来的结果都是正确的。但是在支持 gbase 的时候发现这种获取时间的 方式行不通,无论通过什么时区拿到的时间 long 值都是一样的,导致格式化数据 不正确。
回答
获取时间和格式化时间代码如下:
while (rs.next()) {
Calendar cal =
Calendar.getInstance(TimeZone.getTimeZone("GMT+00:00"));
Date date = rs.getTimestamp(1,cal);
Date date1 = rs.getTimestamp(1);
System.out.println("按照本地时区获取时间:" + date1.getTime());
System.out.println("本地时区获取时间后格式化:" + sf.format(date1));
sf.setTimeZone(TimeZone.getTimeZone("GMT+00:00"));
System.out.println("按照 GMT0 时区获取时间:" + date.getTime());
System.out.println("GMT0 时区获取时间后格式化:" + sf.format(date));
}

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论