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.

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...