在PreparedStatement中使用setDate
在您提供的代码中,您希望使用PreparedStatement将日期值插入到SQL表中。使用 setDate() 时,了解应传递的日期值的格式非常重要。
使用 java.sql.Date
对于以下列键入 DATE,使用设置值时有多个选项java.sql.Date:
-
java.lang.String:表示日期的字符串必须采用“yyyy-MM-dd”格式。
-
java.util.Date:使用 new 将 java.util.Date 转换为 java.sql.Date java.sql.Date(endDate.getTime()).
-
当前时间戳:使用 new java.sql.Date(System.currentTimeMillis()) 设置当前日期。
使用java.sql.Timestamp
对于 TIMESTAMP 或 DATETIME 类型的列,使用 java.sql.Timestamp:
-
java.lang.String :表示时间戳的字符串必须采用“yyyy-MM-dd”格式HH:mm:ss[.f...]."
-
java.util.Date:使用新的 java.util.Date 将 java.util.Date 转换为 java.sql.Timestamp。 sql.Timestamp(endDate.getTime()).
-
当前时间戳:使用 new java.sql.Timestamp(System.currentTimeMillis()) 设置当前时间戳。
在您的情况下,请确保 vDateMDY 字符串的格式正确,“yyyy-MM-dd HH:毫米:SS。”如果不是,您将需要为您的 SQL 列数据类型使用适当的格式,或者考虑在 SQL 语句本身中使用 setString() 和 to_date() 转换。
以上是如何在PreparedStatement中针对不同的日期和时间戳数据类型正确使用setDate?的详细内容。更多信息请关注PHP中文网其他相关文章!