ibatis配置xml文件中CDATA的用法


 ibatis作為一種半自動化的OR Mapping工具,其靈活性日益體現出來,越來越多的人都傾向於在項目中使用。由於Sql中經常有與xml規范相沖突的字符對xml映射文件的合法性造成影響。許多人都知道使用<![CDATA[   ]]>標記來避免沖突,但是在sql配置中有動態語句的時候,還是有一些細節需要特別注意的。

        在使用ibatis時,經常需要配置待執行的sql語句。使用過ibatis的朋友都知道,無可避免的都會碰到一些不兼容、沖突的字符,多數人也都知道用<![CDATA[   ]]>標記避免Sql中與xml規范相沖突的字符對xml映射文件的合法性造成影響。但是,如果在ibatis中使用了動態語句的時候,還是有一些細節需要注意。下面舉例說明一下:
 
環境:oracle、ibatis、java
 
錯誤例1:符號“<=”會對xml映射文件的合法性造成影響
[html]  view plain  copy
 
<select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long">  
<![CDATA[    
select id 
from tableA a, 
     tableB b 
 <dynamic prepend="WHERE"> 
 <isNotNull prepend="AND" property="startDate"> 
  a.act_time >= #startDate#  
  and a.act_time <= #endDate# 
  and a.id = b.id  
 </isNotNull>     
 </dynamic>   
  ]]>  
</select>  

錯誤例2:將整個sql語句用<![CDATA[   ]]>標記來避免沖突,在一般情況下都是可行的,但是由於該sql配置中有動態語句(where部分),將導致系統無法識別動態判斷部分,導致整個sql語句非法。
 
[html]  view plain  copy
 
<select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long">    
select id  
from tableA a,  
     tableB b  
 <dynamic prepend="WHERE">  
 <isNotNull prepend="AND" property="startDate">  
  a.act_time >= #startDate#   
  and a.act_time <= #endDate#  
  and a.id = b.id   
 </isNotNull>      
 </dynamic>    
</select>  

 

 
 
正確做法:縮小范圍,只對有字符沖突部分進行合法性調整。
 
[html]  view plain  copy
  1. <select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long">    
    select id  
    from tableA a,  
         tableB b  
     <dynamic prepend="WHERE">  
     <isNotNull prepend="AND" property="startDate">  
      a.act_time >= #startDate#   
      <![CDATA[ and a.act_time <= #endDate#  ]]>  
      and a.id = b.id   
     </isNotNull>      
     </dynamic>    
    </select>  
總結:
在用CDATA的時候,只用把可能產生沖突的那段代碼包含就可以了,不要盲目的包含。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM