我正在使用 MyBatis 来映射一些需要比较的查询String
争论 (myString
).
我的地图绘制者界面 is:
public Map<Integer, String> findSomething(@Param("myString") String myString);
My XML如下:
<select id="findSomething" parameterType="String" resultType="Map">
SELECT column1 as key,
column2 as value
FROM my_table
<where>
<choose>
<when test="myString == 'xxx'">
column3 = 1
</when>
<when test="myString == 'yyy'">
myColumn = 2
</when>
<when test="myString == 'zzz'">
myColumn = 3
</when>
</choose>
</where>
ORDER BY value;
</select>
当我执行此语句时,会引发以下错误:
ERROR [stderr] Caused by: org.apache.ibatis.exceptions.PersistenceException:
ERROR [stderr] ### Error querying database. Cause: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'myString' in 'class java.lang.String'
A String
这样一对比,就臭了。不幸的是,这是数据库建模的方式。
MyBatis 版本:3.2.2
使用 MyBatis 3.2.8 进行测试
<select id="findSomething" parameterType="String" resultType="Map">
SELECT column1 as key,
column2 as value
FROM my_table
<where>
<choose>
<when test='"xxx".equals(myString)'>
column3 = 1
</when>
<when test='"yyy".equals(myString)'>
myColumn = 2
</when>
<when test='"zzz".equals(myString)'>
myColumn = 3
</when>
</choose>
</where>
ORDER BY value;
</select>
请注意 test 周围的单引号和 de 常量值周围的双引号。如您所见,诀窍是使用 equals。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)