繁体   English   中英

带有PreparedStatement.setTimestamp的Java JDBC SQL语法错误。 时间在冒号':'处被截断

[英]Java JDBC SQL Syntax error with PreparedStatement.setTimestamp. Value gets cut off at the colon ':' in time

每当我尝试执行一个准备好的语句时,它都会引发一个MySQLSyntaxErrorException与:

您的SQL语法有误; 检查与您的手册相对应的手册
在正确的语法下使用MySQL服务器版本,以在'INSERT INTO Information(stamp)VALUES('2017-01-24 1'at ** line 1

看起来它在格式的时间部分的冒号“:”处被切断了。

String sql = "INSERT INTO Information (stamp) VALUES (?);"
...
statement.setTimeStamp(1, new Timestamp(system.currentTimeMillis()));

我尝试了多种获取系统时间戳并将其转换为java.sql.Timestamp的方法,但是它仍然会引发相同的错误。

我的表具有类型为TIMESTAMP的列标记。

我发现了问题。 我没有意识到准备好的语句不允许多个查询。 我的选择是在发送连接请求时使用两个语句或添加连接参数

?allowMultipleQueries=true 这允许多个查询以分号分隔。 谢谢你们!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM