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 (select rownum rownum_,row_.* from (select * from
MC$$ASSET_RECYCLE_CODE
<dynamic prepend="WHERE">
<isNotEmpty prepend="AND" property="searchParameters.owner">//此处第一个条件要加and
upper(owner) like upper('%$searchParameters.owner$%')
</isNotEmpty>
<isNotEmpty prepend="AND" property="searchParameters.otype">
upper(otype) like upper('%$searchParameters.otype$%')
</isNotEmpty>
</dynamic>
)row_)
<isEqual prepend="WHERE" property="paged" compareValue="true">
rownum_ between #startNumber# and #endNumber# order by OPTIME desc
</isEqual>
</select>
B :ibatis在调用过程或函数的过程中,大括号不能分成两行。代码如下:
<procedure id="auditselect_getById" parameterMap="AuditSelectshowDetails">
{? = call tlgadmin.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" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-config-2.dtd ">
<sqlMapConfig>
<settings cacheModelsEnabled="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" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
" http://www.ibatis.com/dtd/sql-map-config-2.dtd ">
<sqlMapConfig>
<settings cacheModelsEnabled="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才能找到。
先写到这吧。