INSERT INTO hotspot(timestamp) VALUES (timestamp with time zone '2012-10-25 14:00:00 +05:00' at time zone 'EET');
我想将时间戳作为变量传递.
我的时间戳列是带时区的时间戳类型.
你知道如何做到这一点吗?
当我做…(Java,Postgresql)
String stm= "INSERT INTO hotspot(timestamp) VALUES(timestamp with time zone ? at time zone 'EET')"; pst = con.prepareStatement(stm); pst.setString(1,"2012-08-24 14:00:00 +05:00"); pst.executeUpdate();
我在“$1”或附近收到语法错误
无论如何我能克服这个错误吗?
先感谢您!!
更新:我尝试通过以下方式使用setTimestamp …
Calendar c=Calendar.getInstance(TimeZone.getTimeZone("GMT+05:00")); String stm= "INSERT INTO hotspot(timestamp) VALUES(?)"; pst = con.prepareStatement(stm); pst.setTimestamp(1,Timestamp.valueOf("2012-01-05 14:00:00"),c ); pst.executeUpdate();
我想数据库中的正确值应该是(关于我的本地时区是EET(02))
2012-01-05 11:00:00 02
但使用pgadmin我检查值,我得到
2012-01-05 14:00:00 02
有什么建议?
解决方法
编辑:正如我在评论中解释的那样,使用三个参数检查API reference for setTimestamp():
Sets the designated parameter to the given java.sql.Timestamp value,using the given Calendar object. The driver uses the Calendar object to construct an sql TIMESTAMP value,which the driver then sends to the database. With a Calendar object,the driver can calculate the timestamp taking into account a custom timezone. If no Calendar object is specified,the driver uses the default timezone,which is that of the virtual machine running the application.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。