问题代码
问题: data字段是NCLOB类型,而foreach标签目的是使用select…union生成一个临时表用于批量插入冲突时更新,但是union有去重的作用,oracle去重时不能使用NCLOB字段作为关键字,会出现 “ORA-00932: 数据类型不一致: 应为 -, 但却获得 CLOB “ 错误。
begin
MERGE INTO user drsd USING
(
<foreach collection="list" item="module" index="index" separator="union">
SELECT #{module.meid, jdbcType=NVARCHAR} meid, #{module.data, jdbcType=NCLOB} data,
#{module.md5, jdbcType=NVARCHAR} md5, #{module.companyId, jdbcType=NUMERIC} company_id,
#{module.createTime, jdbcType=DATE} create_time
FROM DUAL
</foreach>
) tmp
ON (drsd.meid = tmp.meid and drsd.md5 = tmp.md5)
WHEN MATCHED THEN
UPDATE SET update_time = sysdate
WHEN NOT MATCHED THEN
INSERT (meid, data, md5, create_time)
VALUES (tmp.meid, to_char(tmp.data), tmp.md5, tmp.create_time)
;end;
解决方法
利用oracle特性,begin…end语句块一次连接,执行多条语句
begin
<foreach collection="list" item="module" index="index" separator=";">
MERGE INTO user drsd USING
(
SELECT #{module.meid, jdbcType=NVARCHAR} meid, #{module.data, jdbcType=NCLOB} data,
#{module.md5, jdbcType=NVARCHAR} md5, #{module.createTime, jdbcType=DATE} create_time
FROM DUAL
) tmp
ON (drsd.meid = tmp.meid drsd.md5 = tmp.md5)
WHEN MATCHED THEN
UPDATE SET update_time = sysdate
WHEN NOT MATCHED THEN
INSERT (meid, data, md5, create_time)
VALUES (tmp.meid, tmp.data, tmp.md5,tmp.create_time)
</foreach>
;end;