ibatis的isequal_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,否则会报错。代码如下:

parameterClass

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

resultMap

="recycle_codeList">

select * from (select rownum rownum_,row_.* from (select * from

MC$$ASSET_RECYCLE_CODE

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

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

property="searchParameters.otype">

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

)row_)

rownum_ between #startNumber# and #endNumber# order by OPTIME desc

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

{? = call tlgadmin.GetSingleDetailrows(?)}

假如改成:

{

? = call tlgadmin.GetSingleDetailrows(?)

}

这样会报错。

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

/p>

PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"

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

">

enhancementEnabled="true" errorTracingEnabled="true"

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

maxTransactions="10" />

1

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

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

3

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

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

/p>

PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"

"

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

">

enhancementEnabled="true" errorTracingEnabled="true"

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

maxTransactions="10" />

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

1

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

3

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

这样ibatis才能找到。

先写到这吧。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值