博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java mybatis 框架下多种类型的参数传入到xml问题
阅读量:4607 次
发布时间:2019-06-09

本文共 1322 字,大约阅读时间需要 4 分钟。

  由于公司要求,最近从.net向java 转,然后过程中遇到各种奇葩问题,特在此随记一番。

  场景:一个方法中有两个参数,一个List的集合,一个int 类型的参数,最初我在xml的sql参数,无论定义成List还是int都报错,其实仔细一想就能明白,接口方法中定义了两个类型的参数,所以你XML中的参数类型无论定义成什么都是不对的。

    原始写法:

//========================这个例子是原始错误写法的例子===========Start

void batchUpdateUrgetntStatusNew(List<String> li,int Priority); 

XML中: 

<!-- 修改借款工单优先级 -->

<update id="batchUpdateUrgetntStatusNew" parameterType="java.util.List">

update   表名

<set>
PRIORITY=#{Priority,jdbcType=INTEGER},
MODIFIEDON=NOW()
</set>
where DELETE_STATUS=0 and LOANEE_TYPE=0
and LOANEE_APPLY_ID in
<foreach collection="li" item="item" index="index" separator=","
open="(" close=")">
#{item}

</foreach>

</update>

//========================这个例子是原始错误写法的例子===========End

 

 

  后来问了一下公司的同事,同事告诉我这样的情况XML中就不要再定义参数类型了,然后改了一下,运行调试ok。

下面是改后的例子

//例子: @Param("li")  为参数起别名,xml可直接使用别名

void batchUpdateUrgetntStatusNew(@Param("li")List<String> li,@Param("Priority")int Priority);

 

XML:中则不用声明参数类型,parameterType="java.util.List"

 

<!-- 修改借款工单优先级 -->

<update id="batchUpdateUrgetntStatusNew">

update   表名

<set>
PRIORITY=#{Priority,jdbcType=INTEGER},
MODIFIEDON=NOW()
</set>
where DELETE_STATUS=0 and LOANEE_TYPE=0
and LOANEE_APPLY_ID in
<foreach collection="li" item="item" index="index" separator=","
open="(" close=")">
#{item}

</foreach>

</update>

转载于:https://www.cnblogs.com/yangjinwang/p/5843103.html

你可能感兴趣的文章
Minimum Path Sum
查看>>
Remove Duplicates from Sorted Array II
查看>>
常量指针和指针常量巧妙记忆方法[转]
查看>>
python-haproxy作业讲解视频总结
查看>>
mui搜索框 搜索点击事件
查看>>
select2 下拉搜索控件
查看>>
WebAPI常见的鉴权方法,及其适用范围
查看>>
08. 删除重复&海量数据
查看>>
重新想象 Windows 8 Store Apps (71) - 其它: C# 调用 C++
查看>>
发布mvc遇到的HTTP错误 403.14-Forbidden解决办法
查看>>
记录一些好用的工具
查看>>
超链接样式设置(去下划线)(转)
查看>>
2016012003+陈琦+散列函数的应用及其安全性
查看>>
Android 状态栏通知Notification、NotificationManager详解
查看>>
UIApplicationDelegate协议
查看>>
Jmeter测试dubbo接口填坑
查看>>
[zz]GDB调试精粹及使用实例
查看>>
数据库的创建和删除
查看>>
最简单的三层实例【插入据
查看>>
设计模式学习笔记——Prototype原型模式
查看>>