MyBatis mapper.xml中使用静态常量或者静态方法

使用MyBatis技术,书写mapper.xml时,如果在其中的ognl表达式或者sql中直接使用一些数字或者字符串的话,会造成难以维护的问题。

在Java编码中,我们通常会把这些数字或者字符串定义在常量类或者接口中,如果在mapper.xml中也可以使用这些常量就比较好了。

还好MybBatis是支持这样的需求的。

ongl中:

比如我有一个工具类com.wts.test.DateUtil,其中有一个方法isLeapYear(int year),用于判断某年是否闰年。而在mapper的某个select中要根据是否闰年执行不同的查询。可以类似这样:

<if test="@com.wts.test.DateUtil@isLeapYear(year)==true">
  select * from tableA
</if>
<if test="@com.wts.test.DateUtil@isLeapYear(year)==false">
  select * from tableB
</if>

 
 
  • 如果要使用常量的话,假设有常量类和常量Constant.CURRENT_YEAR:

    <if test=year==@com.wts.test.Consant@CURRENT_YEAR>
      select * from tableC
    </if>
    

 sql中:

使用静态方法:

<select id='testSelectA' .....>
  select * from tableA where year=${@com.wts.test.DateUtil@getYear()}
</select>

使用静态常量:

<select id='testSelectB' .....>
  select * from tableA where year=${@com.wts.test.Constant@CURRENT_YEAR}
</select>

 
 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值