这是ibatis sqlmap中的 sql
parameterClass="com.spci.po.MemberMerchant">
<![CDATA[
insert INTO t_member_credit (ID,MEMBER_ID,TRADE_ID,BALANCE)
VALUES (#id#,#memberId#,#tradeId#,#balance#)
ON DUPLICATE KEY UPDATE
BALANCE=#balance#
]]>
这是DAO种的执行代码
public void bathInsertObject(final String sql, final List list) {
try {
//this.getSqlMapClient().startTransaction();
this.getSqlMapClient().startBatch();
for (int i = 0; i < list.size(); i++) {
this.insertObject(sql, list.get(i));
}
//this.getSqlMapClient().commitTransaction();
//this.getSqlMapClient().endTransaction();
this.getSqlMapClient().executeBatch();
} catch (SQLException e) {
logger.error("批量添加错误"+sql,e);
}
}
目的:为了实现mysql中存在数据就批量新增 不存在就批量更新,上面的sql已经在数据库中执行sql验证可用
结果:通过Ibatis调用后 只新增了一条数据,而不是多条
PS:在执行普通的批量新增时 上面的代码是可用的
请问哪里出错了?如何解决