循环插入时statement需要每次循环都创建吗

 我来答
聚发稿网
2016-08-04 · 知道合伙人生活技巧行家
聚发稿网
知道合伙人生活技巧行家
采纳数:5647 获赞数:29663
聚发稿网创始人,作家,笔名志耘誉松著《机械魔敌》《笑泪恋曲》

向TA提问 私信TA
展开全部
,?,?,?,now(),0);用prepareStatement进行插入,如何获取该语句自动生成的键值呢?以下为一段相关的代码,你可以找到答案哦!表article对应的字段为(id,pid,rootid,title,content,date,isleaf)Connectionconn=DriverManager.getConnection();//将自动提交设置为falseBooleanisAuto=conn.getAutoCommit();conn.setAutoCommit(false);Stringsql="insertintoarticlevalues(null,?,?,?,?,now(),0)";PreparedStatementpstmt=conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);pstmt.setInt(1,);pstmt.setInt(2,0);//rootid暂设为0pstmt.setString(3,);pstmt.setString(4,);pstmt.execute();//获得自动生成的键值ResultSetrs=pstmt.getGeneratedKeys();rs.next();intid=rs.getInt(1);//将刚才插入的记录中的rootid改为id的值Statementstmt=conn.createStatement(conn);sql="updatearticlesetrootid="+id+"whereid="+id;stmt.executeUpdate(sql);//将自动提交恢复现场conn.commit();conn.setAutoCommit(isAuto);调试这段代码的时候遇到一个bug,说是有语法错误,最终确定是sql="updatearticlesetrootid="+id+"whereid="+id;的错误。找了半天,终于找到错误点,你能区分下面两条语句的不同吗?(第二条为正确语句!万恶的空格呀。。。呀。。。呀。。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式