mybatis xml sql语句报错:大于号、小于号的转义写法 Error creating document instance

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,转义字符

                 &lt;                                 

                 <

                 小于号                                           

                 &gt;

                 >                                      

                 大于号

                 &amp;

                 &

                 和

                 &apos;

                 ’

                 单引号

                 &quot;

                 "

                 双引号

例如: 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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值