当我们需要通过xml格式处理sql语句时,经常会用到< ,<=,>,>=等符号,但是很容易引起xml格式的错误,这样会导致后台将xml字符串转换为xml文档时报错,从而导致程序错误。
这样的问题在iBatiS中或者自定义的xml处理sql的程序中经常需要我们来处理。其实很简单,我们只需作如下替换即可避免上述的错误:
原符号 |
< |
<= |
> |
>= |
& |
' |
" |
替换符号 |
< |
<= |
> |
>= |
& |
' |
" |
错误的xml格式:
1
2
3
4
|
<?xml version= "1.0" encoding= "GBK" ?> <queryForm token= "32sdfj-349sfdnfs32-fsdf348imfg323-df34" tableName= "HSY_T_CUSTOMER" pageSize= "20" pageNo= "1" orderColumn= "" orderType= "" > <sqlCondition> AND START_DATE >= to_date( '2013-01-01' , 'yyyy-MM-dd' ) AND START_DATE <= to_date( '2013-01-30' , 'yyyy-MM-dd' ) </sqlCondition> </queryForm> |
在altova XMLSpy工具中会报错,xml不符合格式要求。
正确的xml格式:
1
2
3
4
|
<?xml version= "1.0" encoding= "GBK" ?> <queryForm token= "32sdfj-349sfdnfs32-fsdf348imfg323-df34" tableName= "HSY_T_CUSTOMER" pageSize= "20" pageNo= "1" orderColumn= "" orderType= "" > <sqlCondition> AND START_DATE >= to_date( '2013-01-01' , 'yyyy-MM-dd' ) AND START_DATE <= to_date( '2013-01-30' , 'yyyy-MM-dd' ) </sqlCondition> </queryForm> |
总结
以上所述是小编给大家介绍的MyBatis SQL xml处理小于号与大于号正确的格式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://blog.csdn.net/zianY/article/details/80564541