我正在尝试将日期插入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: Data truncation: Incorrect date value: '1980' for column 'device_sales_details_DOA' at row 1
Sysout
打印如下输入22/12/2014
Date22Month11Year114
如何解决这个问题,任何人都可以帮助我。
答案 0 :(得分:5)
使用PreparedStatement
。使用字符串连接来创建通过JDBC发送的SQL代码几乎永远不正确。
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 (?)