hibernate 循环实际只执行了一次sql语句,该解决
hibernate 循环为什么实际只执行了一次sql语句
A与B之间是一对多的
bList有2个B的实例
执行时,b有2个,
B的id生成方式是sequence
Java code
for (int i = 0; i bList.size(); i++) {
B bPO = (B)bList.get(i);
bPO .setA(aPO);
this.bDAO.saveB(bPO);
}
调试时,确实循环了两次,但最终只执行了一次sql语句,插入了一条记录
问题可能是什么原因,
------解决
方案
气瓶 现场处置方案 .pdf气瓶 现场处置方案 .doc见习基地管理方案.doc关于群访事件的化解方案建筑工地扬尘治理专项方案下载
--------------------------------------------------------
可能saveB这方法写错了,
for (loop) {
sql = XXXXXXXX ;
// 应该在这里执行sql;
}
// 实际在这里执行sql;
你先试试。。。
for (int i = 0; i bList.size(); i++) {
sql = XXXXXXX ;
executeSql();
}
------解决方案--------------------------------------------------------
你bList的2条数据是不是相同的,
------解决方案--------------------------------------------------------
然后你saveB里面用的是saveOrUpdate而不是用的save
------解决方案--------------------------------------------------------
很有可能就是两次执行的id相同,hibernate在第二次会当成更新