gpt4 book ai didi

java - 如何将日期插入mysql?

转载 作者:行者123 更新时间:2023-11-29 01:28:31 24 4
gpt4 key购买 nike

我正在尝试将日期插入到 mySql 数据库中。我接受日期作为字符串并将其解析为 util.Date 然后将其转换为 sql.Date 然后我插入到数据库中。这是我的代码

SimpleDateFormat format = new SimpleDateFormat("dd/MM/yyyy"); 
String mydate=dsd.getDoa();
Date mydate2=format.parse(mydate);
java.sql.Date sqlDate;
sqlDate = new java.sql.Date(mydate2.getTime());
System.out.println("Date"+sqlDate.getDate()+"Month"+sqlDate.getMonth()+"Year"+sqlDate.getYear());

....

int i=st.executeUpdate("insert into device_sales_details values("+sqlDate+"));

错误如下,

com.mysql.jdbc.MysqlDataTruncation:数据截断:日期值不正确:第 1 行的“device_sales_details_DOA”列为“1980”

Sysout 打印如下输入 22/12/2014

Date22Month11Year114 如何解决这个问题,谁能帮我解决这个问题。

最佳答案

使用 PreparedStatement .使用字符串连接创建 SQL 代码以通过 JDBC 发送几乎是不正确的。

PreparedStatement ps = connection.prepareStatement("insert into device_sales_details values(?)");
ps.setDate(1, sqlDate);
int i = ps.executeUpdate();

更多关于此处不使用字符串连接的信息:http://bobby-tables.com


另外,通常最好在插入时指定列,例如:insert into device_sales_details (columnName) values (?)

关于java - 如何将日期插入mysql?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27617154/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com