我的BUG日志(2020071901):mybatis注解开发中的OGNL表达式语法问题,小于号要写成转义小于号,大于号要写成转义大于号

本文记录了一次在MyBatis注解开发中遇到的OGNL表达式语法问题,导致项目无法正常读取数据库。错误源于小于号和大于号未转义,以及不正确的equals使用。解决办法是将小于号写成转义小于号,大于号写成转义大于号,并使用原始的'!='代替'equals'。
摘要由CSDN通过智能技术生成

由于在dao层的一个文件写出错了注解,导致了整个项目无法读取数据库。mybatis的这个设定真是糟糕透顶,所以说写ognl表达式来对数据库CRUD的时候一定要小心。控制台报出的错误如下:

Error building SqlSession.

The error may exist in com/itheima/travel/dao/FavoriteMapper.java
(best guess) ### Cause: org.apache.ibatis.builder.BuilderException:
Error parsing SQL Mapper Configuration. Cause:
org.apache.ibatis.builder.BuilderExcep Could not find value method on
SQL annotation

错误代码:

@Select("    <script>\n"
        + "        select count(*) from tab_route\n"
        + "        <where>\n"
        + "         rflag=1 \n"
        + "        <if test=\"rname!=null and  !''.equals(rname)\">\n"
        + "        and rname like concat('%',#{rname},'%')\n"
        + "        </if>\n"
        + "        <if test=\"price1!=null and price2!=null\">\n"
        + "            and price >= #{price1} and price <= #{price2}\n"
        + "        </if>\n"
        + "        </where>\n"
        + "    </script>")
int findFavoriteCount(@Param("rname") String rname,
                      
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值