单参数传递:可以直接使用
column="col"
的形式将参数传递
多参数传递:column="{prop1=col1,prop2=col2}"
,其中prop1,prp2
为自查询中要用#{}插入的参数名称
问题发现
对于多参数传递过程中,如果传的是string
类型的变量,会报出There is no setter for property named 'byte' in 'class java.lang.String'
错误,但如果是int
类型或者是单参数的string
类型传递,则不会出现这样的错误
问题解决
发现是在子查询中使用parameterType="string"
限定了传入的参数类型,将这个可选项去掉,问题解决
原因猜测
对于单参数传递,内部实现直接采用\(=\)的直接赋值方法,因此单参数时即使限定了parameterType="string"
不会报错
对于多参数传递,如果使用了parameterType
,则会将传入的prop
视为该类型的成员变量名,调用其set方法进行赋值,如果没有使用,默认为unset
,则对传入参数类型未知,内部实现也直接采用\(=\)的直接赋值方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。