PreparedStatement.setDate问题求教

snowOnwest 2008-04-29 05:39:29
如下一段程序:
java.sql.Date dt=new java.sql.Date(year-1900,month-1,day);
String sql="Insert into stock values(?,?,?,?,?,?,?,?,?)";
PreparedStatement pstmt=conn.prepareStatement(sql);
pstmt.setDate(3,dt);
每次执行到pstmt.setDate(3,dt)的时候报错“java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]没有执行可选特性”,
请教各位大侠如何解决这个问题?谢谢!
...全文
556 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
snowOnwest 2008-05-03
  • 打赏
  • 举报
回复
SQL SERVER中datetime对应java中java中timeStamp类型,问题已解决,谢谢各位。
loujianchengdd 2008-04-30
  • 打赏
  • 举报
回复
数据库中也用Date应该就没问题了。
snowOnwest 2008-04-30
  • 打赏
  • 举报
回复
JDK文档对void setDate(int parameterIndex,Date x)的解释是“Sets the designated parameter to the given java.sql.Date value using the default time zone of the virtual machine that is running the application.”,第二个参数类型应该是java.sql.Date类型吧,用Timestamp和new Date(System.currentTimeMillis())试过也不能解决问题,比较奇怪。
anqini 2008-04-29
  • 打赏
  • 举报
回复

new Date(System.currentTimeMillis());//可否?
或者System.currentTimeMillis();
wopopo 2008-04-29
  • 打赏
  • 举报
回复
datetime

smalldatetime

TIMESTAMP

java.sql.Timestamp

sqlserver中的 datetime应该对应java.sql中的timestamp ,不是date

snowOnwest 2008-04-29
  • 打赏
  • 举报
回复
呵呵,楼上,只是其中一段代码,数据库中第三个字段是datetime类型,执行setDate为什么会报错呢?
anqini 2008-04-29
  • 打赏
  • 举报
回复

// 这不是完整程序吧.
java.sql.Date dt=new java.sql.Date(year-1900,month-1,day);
String sql="Insert into stock values(?,?,?,?,?,?,?,?,?)";
PreparedStatement pstmt=conn.prepareStatement(sql);
pstmt.setDate(3,dt);

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧