码迷,mamicode.com
首页 > 数据库 > 详细

mybatis 使用oracle merge into 语句踩坑实录

时间:2017-12-27 18:09:38      阅读:543      评论:0      收藏:0      [点我收藏+]

标签:入库   order   acl   timestamp   amp   seq   set   value   解决   

由于需求涉及oracle的clob类型字段,在mybatis的mapper xml文件中编写merge into语句时总是失败。

附上错误代码

<insert id="mergeInto">
        <selectKey resultType="java.lang.String" order="BEFORE"
            keyProperty="id">
            SELECT to_char(sysdate,‘yyyymmdd‘)||seq_dr_bcxx.nextval
            AS ID FROM dual
        </selectKey>
        MERGE INTO dr_doc_info doc
        USING (SELECT #{cankwxzwtm} cankwxzwtm,
        #{zz} zz FROM dual) d
        ON (doc.cankwxzwtm = d.cankwxzwtm and doc.zz =
        d.zz)
        WHEN matched THEN
        UPDATE SET doc.MOD_TIME =
        #{modTime},doc.UPD_USER = #{updUser}
        WHEN not matched THEN
        INSERT (
        ID,
        CKWXLX,
        CANKWXBH,
        CANKWXZWTM,
        CANKWXYWTM,
        ZZ,
        DYZZXM,
        DIYZZDW,
        DYZZDZ,
        TXZZDZ,
        TXZZXM,
        TXZZDW,
        KANM,
        YEAR,
        JUAN,
        QI,
        YEMA,
        ZWGJC,
        YWGJC,
        <!-- zhongwzy, YINGWZY, -->
        FUND_TYPE,
        FLH,
        IS_OPEN,
    <!--     CKWXLY, -->
        REG_TIME,
        MOD_TIME,
        MEMO,
        CRT_USER,
        UPD_USER
        )VALUES(
        #{id,jdbcType=VARCHAR},
        #{ckwxlx,jdbcType=VARCHAR},
        #{cankwxbh,jdbcType=VARCHAR},
        #{cankwxzwtm,jdbcType=VARCHAR},
        #{cankwxywtm,jdbcType=VARCHAR},
        #{zz,jdbcType=VARCHAR},
        
        #{dyzzxm,jdbcType=VARCHAR},
        #{diyzzdw,jdbcType=VARCHAR},
        #{dyzzdz,jdbcType=VARCHAR},
        #{txzzdz,jdbcType=VARCHAR},
        #{txzzxm,jdbcType=VARCHAR},
        #{txzzdw,jdbcType=VARCHAR},
        #{kanm,jdbcType=VARCHAR},
        
        #{year,jdbcType=VARCHAR},
        #{juan,jdbcType=VARCHAR},
        #{qi,jdbcType=VARCHAR},
        #{yema,jdbcType=VARCHAR},
        #{zwgjc,jdbcType=VARCHAR},
        #{ywgjc,jdbcType=VARCHAR},
        <!-- #{zhongwzy,jdbcType=CLOB,typeHandler=org.apache.ibatis.type.ClobTypeHandler}, 
            #{yingwzy,jdbcType=CLOB,typeHandler=org.apache.ibatis.type.ClobTypeHandler}, -->
        #{fundType,jdbcType=VARCHAR},
        #{flh,jdbcType=VARCHAR},
        #{isOpen,jdbcType=VARCHAR},
        <!-- #{ckwxly,jdbcType=VARCHAR}, -->
        #{regTime,jdbcType=TIMESTAMP},
        #{modTime,jdbcType=TIMESTAMP},
        #{memo,jdbcType=VARCHAR},
        #{crtUser,jdbcType=VARCHAR},
        #{updUser,jdbcType=VARCHAR}
        )
    </insert>

 

主要有三点问题,

1,clob类型的字段比较 要借助函数 dbms_lob.compare() 。

2,clob字段手写insert入库失败(未解决)。

3,借助存储过程成功了(不想用存储过程)。

mybatis 使用oracle merge into 语句踩坑实录

标签:入库   order   acl   timestamp   amp   seq   set   value   解决   

原文地址:https://www.cnblogs.com/zzt-lovelinlin/p/8125765.html

(0)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!