ibatis的动态sql,call proc等需要注意的地方(经验总结)

1环境:ibatis2.3,spring2.5.

     2最近项目里用 spring2.5+ibatis2.3做开发。ibatis主要是用它的动态sql.用ibatis有一段时间了。准备给自己备个案,把ibatis2.3使用过程中需要注意的地方给记录下来。并且分享给大家。

     3下面写几点自己遇到过的要注意的问题。

     A:平常的sql语句比如select * from table where username='admin' and password='admin'(这是个容易被注入的语句)在where后面的第一个条件是不需要and的,从第二个查询条件起才需要and.但在配置ibatis的动态sql时一定要在第一个条件前加上and,否则会报错。代码如下:

   <select id="Recycle_getPageList"

parameterClass="com.hzmc.common.domain.Page"

resultMap="recycle_codeList">

select*from(selectrownumrownum_,row_.*from(select*from

MC$$ASSET_RECYCLE_CODE

<dynamicprepend="WHERE">

<isNotEmptyprepend="AND"property="searchParameters.owner">//此处第一个条件要加and

upper(owner)likeupper('%$searchParameters.owner$%')

</isNotEmpty>

<isNotEmptyprepend="AND"property="searchParameters.otype">

upper(otype)likeupper('%$searchParameters.otype$%')

</isNotEmpty>

</dynamic>

)row_)

<isEqualprepend="WHERE"property="paged"compareValue="true">

rownum_between#startNumber#and#endNumber#orderbyOPTIMEdesc

</isEqual>

   </select>

   B :ibatis在调用过程或函数的过程中,大括号不能分成两行。代码如下:

     <procedure id="auditselect_getById" parameterMap="AuditSelectshowDetails">  

{?=calltlgadmin.GetSingleDetailrows(?)}

     </procedure>  

     假如改成:

    <procedure id="auditselect_getById" parameterMap="AuditSelectshowDetails">           {

          ? = call tlgadmin.GetSingleDetailrows(?)

        }      </procedure>  

这样会报错。

  C关于sqlmap-config.xml文件的问题:假如一个配置文件要引用另一个配置文件,那么被应用的配置文件要放在引用配置文件的前面。否则,ibatis会报找不到错误(这应该是ibatis2.3的一个bug).

 <?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPEsqlMapConfig

PUBLIC"-//iBATIS.com//DTDSQLMapConfig2.0//EN"

"http://www.ibatis.com/dtd/sql-map-config-2.dtd">

<sqlMapConfig>

<settingscacheModelsEnabled="true"lazyLoadingEnabled="true"

enhancementEnabled="true"errorTracingEnabled="true"

useStatementNamespaces="false"maxRequests="30"maxSessions="20"

maxTransactions="10"/>

1<sqlMap

resource="com/hzmc/capaa/domain/persistence/trustuser/AdminUser.xml"/>

2<sqlMap

resource="com/hzmc/capaa/domain/persistence/verifyfactor/IpAddress.xml"/>

3<sqlMap

          resource="com/hzmc/capaa/domain/persistence/verifyfactor/OsUser.xml" />

</sqlMapConfig>

     如上:假如1要应用2中的配置,那么这样写就会报错,必须方2在1的前面。

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPEsqlMapConfig

PUBLIC"-//iBATIS.com//DTDSQLMapConfig2.0//EN"

"

http://www.ibatis.com/dtd/sql-map-config-2.dtd">

<sqlMapConfig>

<settingscacheModelsEnabled="true"lazyLoadingEnabled="true"

enhancementEnabled="true"errorTracingEnabled="true"

useStatementNamespaces="false"maxRequests="30"maxSessions="20"

  maxTransactions="10" />

      2 <sqlMap

resource="com/hzmc/capaa/domain/persistence/verifyfactor/IpAddress.xml"/>

1<sqlMap

resource="com/hzmc/capaa/domain/persistence/trustuser/AdminUser.xml"/>

3<sqlMap

          resource="com/hzmc/capaa/domain/persistence/verifyfactor/OsUser.xml" />

</sqlMapConfig>

这样ibatis才能找到。

先写到这吧。

相关推荐