mybatis特殊使用

转义字符

在xml的sql语句中,不能直接用大于号、小于号要用转义字符

转义字符符号解释
&lt;<小于号
&gt;>大于号
&amp;&
&apos;'单引号
&quot ;"双引号

 另一种写法:

小于等于    a<=b                 a &lt;= b                        a <![CDATA[<= ]]>b

大于等于    a>=b                 a &gt;= b                        a <![CDATA[>= ]]>b

不等于      a!=b                 a <![CDATA[ <> ]]>b              a <![CDATA[!= ]]>b

------------------------------------------------------------------------------------------------------------------------------------------------------------------

mybatis xml中if和when的比较字符串相等判断不起作用;

解决方法

把<if test="takeWay == '1' and workday != null ">

改为<if test='takeWay == "1" and workday != null '>

或改为<if test="takeWay == '1'.toString() and workday != null ">即可。

原因是:mybatis是用OGNL表达式来解析的,在OGNL的表达式中,’1’会被解析成字符,java是强类型的,char 和 一个string 会导致不等,所以if标签中的sql不会被解析。 总结下使用方法:单个的字符要写到双引号里面或者使用.toString()才行!

-----------------------------------------------------------------------------------------------------------------------------------------------------------------

/**
 * 验证手机号
 * 
 */
public static boolean checkMobileNumber(String phone) {
    //String regex = "^((13[0-9])|(14[5,7,9])|(15([0-3]|[5-9]))|(166)|(17[0,1,3,5,6,7,8])|(18[0-9])|(19[8|9]))\\d{8}$";
    String regex = "/^(13[0-9]|14[5-9]|15[012356789]|166|17[0-8]|18[0-9]|19[8-9])[0-9]{8}$/";
    if (phone.length() != 11) {
        throw new RRException("手机号应为11位数");
    } else {
        Pattern p = Pattern.compile(regex);
        Matcher m = p.matcher(phone);
        boolean isMatch = m.matches();
        if (!isMatch) {
            throw new RRException("请填入正确的手机号");
        }
        return isMatch;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值