mybatis xml中是sql语句报错: Error creating document instance. Cause: org.xml.sax.SAXParseException
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u013614451/article/details/39576621
收起
最近项目折腾了老半天,找了资料才知道是这么回事。。。
因为语句中有一个小于号“<”,在XML中,会被当成一个页面元素来解析,不会处理为mysql的SQL语句的组成部分,修改如下:
1、在xml的sql语句中,不能直接用大于号、小于号要用转义字符
如果用小于号会报错误如下:
org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException: The content of elements must consist of well-formed character data or markup.
解决办法:
1,转义字符
<
<
小于号
>
>
大于号
&
&
和
'
’
单引号
"
"
双引号
例如: state <= 3 则改成 state <= 3
2、使用<![CDATA[ ]]>标记
注意:<![CDATA[ ]]>标记的sql语句中的 等标签不会被解析
<![CDATA[
state <= 3
]]>
这样,将会把SQL语句中与XML页面元素相同的元素屏蔽,是的XML不将其解析为XML的元素,从而生成正确的SQL语句。
————————————————
版权声明:本文为CSDN博主「毅个混蛋」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u013614451/article/details/39576621