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

在处理GBase数据库时间获取时,发现不同于Oracle、SQL Server和Sybase IQ,GBase无法按照指定时区正确获取和格式化时间。代码示例显示,无论通过哪个时区获取时间,返回的long值始终相同,导致格式化结果错误。这可能涉及到GBase的时区处理机制或API使用问题。

问题
我们现在支持的 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));
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值