转义字符
在xml的sql语句中,不能直接用大于号、小于号要用转义字符
转义字符 | 符号 | 解释 |
---|---|---|
<; | < | 小于号 |
>; | > | 大于号 |
&; | & | 和 |
&apos; | ' | 单引号 |
" ; | " | 双引号 |
另一种写法:
小于等于 a<=b a <= b a <![CDATA[<= ]]>b
大于等于 a>=b a >= 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;
}
}