hxd505 2013-11-10 07:28
浏览 1184

IBATIS像mysql中批量新增问题

这是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:在执行普通的批量新增时 上面的代码是可用的

请问哪里出错了?如何解决

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
    • ¥15 C# datagridview 单元格显示进度及值
    • ¥15 thinkphp6配合social login单点登录问题
    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配