编程语言
首页 > 编程语言> > java – Mybatis If语句使用include属性

java – Mybatis If语句使用include属性

作者:互联网

我正在尝试在Mybatis中创建一个通用SQL包含,它将应用给定特定值的比较器.我们的想法是在几个映射器中重用这个sql代码段.我遇到的问题是在我的include中的if语句中使用字符串替换.

目前xml看起来像这样:

<select id="get" parameterType="ServiceModelQueryHelper" resultMap="ServiceRecordMap">
    SELECT * from service
    <if test="name.isApplicable()">
        WHERE service.name
        <include refid=comparatorMapper>
            <property name="comparator" value="${name.comparator}"/>
            <property name="value" value="${name.value}"/>
        </include>
    </if>
</select>
<sql id="comparatorMapper">
    <if test="${comparator} == 'EQUALS'">
        = ${value}
    </if>
    <if test="${comparator} == 'CONTAINS'">
        ~ ${value}
    </if>
</sql>

当在测试中使用${comparator}时,在字符串替换发生之前评估OGNL表达式,从而导致ParseException,因为$不是有效的第一个字符.

有没有办法在OGNL表达式中引用sql片段的属性?

解决方法:

看看mybatis docs.条件语句不需要#,$样式引用.

标签:java,postgresql,dynamic-sql,mybatis,ognl
来源: https://codeday.me/bug/20190711/1432030.html