繁体   English   中英

无法将java.sql.Date插入数据库中的“ Date”字段

[英]cannot insert java.sql.Date to the “Date” field in the database

我正在获取一个字符串值,例如“ 2012-01-20”,并将其转换为sql.Date,以将其插入数据库中。

java.util.Date DOB = new java.util.Date();
String datetext = txtDate.getText();

SimpleDateFormat sd = new SimpleDateFormat("yyyy-mm-dd");
DOB = sd.parse(datetext);
java.sql.Date sqlDate = new java.sql.Date(DOB.getTime());

String query = "ISERT INTO EMPLOYEE ('DOB')"
                   + " VALUES ( ? ) ";

con = db.createConnection();
 try{
     ps = con.prepareStatement(query);
     ps.setDate(1, sqlDate);
     ps.executeQuery();
    }catch(Exception ex){
       System.err.print(ex);
  }

运行此代码时,出现异常“” [Microsoft] [ODBC SQL Server驱动程序]未实现可选功能”

我在这里做错了什么? 请帮助!

删除单引号-('DOB')和INSERT (misspell)

String query = "INSERT INTO EMPLOYEE (DOB) VALUES (?)";

您可以使用java.sql.Date.valueOf("2012-01-20")方法将字符串转换为sql日期。

使用executeUpdate()方法而不是executeQuery()。

String query = "INSERT INTO EMPLOYEE (DOB) VALUES (?)";

con = db.createConnection();
 try{
     ps = con.prepareStatement(query);
     ps.setDate(1, java.sql.Date.valueOf("2012-01-20"));
     //Or use
     //  ps.setTimestamp(1, new Timestamp(DOB.getTime())); 
     ps.executeUpdate();
    }catch(Exception ex){
       System.err.print(ex);
  }

暂无
暂无

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

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