如何将日期插入mysql?

时间:2014-12-23 09:06:29

标签: java mysql date jdbc java.util.date

我正在尝试将日期插入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如何解决这个问题,任何人都可以帮助我。

1 个答案:

答案 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 (?)