微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgresql – 如何在预准备语句中传递带有”(timestamp)的字符串?

我正在尝试执行以下查询

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

有什么建议?

解决方法

考虑使用setTimestamp()方法而不是setString()方法.检查 this link以了解如何使用PreparedStatement.

编辑:正如我在评论中解释的那样,使用三个参数检查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 举报,一经查实,本站将立刻删除。

相关推荐