JDBC Java 数据库插入语句

publicbooleanupdateDB(Stringsql,String[]paras){booleanb=true;try{ps=ct.prepareStateme... public boolean updateDB(String sql,String [] paras){
boolean b = true;
try {
ps = ct.prepareStatement(sql);
for(int i=0;i<paras.length;i++){
ps.setString(i+1, paras[i]);
}
ps.executeUpdate();
} catch (SQLException e) {
b = false;
e.printStackTrace();
} finally {
close();
}
return b;
}

public boolean insertByDiet(String [] paras){
String sql;
boolean b=false;
try{
sql = "insert into record(cId,bId,mId,borrowDate,returnDate) values(?,?,?,?,?)";
b=updateDB(sql, paras); //更新成功返回true,所以插入成功返回true
}catch(Exception e){
e.printStackTrace();
}
return b;
}

String[]paras1={cid,bid,mid, bdate, rdate};
b=insertByDiet(paras1);
执行的时候,在ps = ct.prepareStatement(sql);这里报错,显示的错误是General error
展开
 我来答
aqyuyang
推荐于2017-11-25
知道答主
回答量:28
采纳率:0%
帮助的人:8.8万
展开全部
你妹的,写了占位符你又不用东西填,sql当然错了,报的sql不完整
两种方案
A。 valuses后的四个问号直接写上参数
B。用import java.sql.PreparedStatement;包下的PreparedStatement方法
预编的方式进行填充示例
PreparedStatement ps = null;

sql = "insert into record(cId,bId,mId,borrowDate,returnDate) values(?,?,?,?,?)";
ps.setInt(1,第一个值);
ps.setInt(2,第二个值);
ps.setInt(3,第三个值);
ps.setInt(4,第四个值);
//提交1234必须写setInt是举例子你看自己的那些字段是什么类型的
ps.executeUpdate();
小童鞋_成er
2013-04-12 · 知道合伙人数码行家
小童鞋_成er
知道合伙人数码行家
采纳数:4650 获赞数:22879
主要从事J2EE工作,热爱Java,用心讨论技术,共同进步。

向TA提问 私信TA
展开全部
您好,提问者:
使用占位符的JDBC增删改查:http://hanchaohan.blog.51cto.com/2996417/925308
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
暨昂雄3A
2013-04-18
知道答主
回答量:25
采纳率:60%
帮助的人:11.2万
展开全部
你的SQL语句中用了占位符,但是你为什么不给占位符设置参数呢?这样肯定会报错啊!
追问
不好意思,设了的,忘了放到问题里了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式