学习ibatis

         最近因项目要求学习了一下ibatis。 项目最开始的框架是spring+struts+hibernate。不知道怎么回事又改用spring+struts+ibatis。

       hiberante是全自动的“OR”机制,ibatis则需要开发人员编写具体的sql语句,相对来说灵活性较大,为系统设计提供了更大的自由空间。ibatis提供了对象与关系数据库之间的映射,同时提供操作方法与SQL间的直接影射,一条sql语句对应一个方法。优化了数据查询,多条件查询和连接查询就更为方便。

简单的插入操作

ibatis的映射文件

xx.xml

< sqlMap  namespace ="UserTest" >
     
< statement  id ="insert"  parameterClass ="com.test.UserTest" >
     INSERT INTO usertest (userid,username,usersex,useremail)
      VALUES(#userid#, #username#, #usersex#, #useremail#)
   
</ statement >
</ sqlMap >

在DAO中相对应的方法就为

xxDAO.java

public   void  addUser(User user)
{
    
//getSqlMapClientTemplate().insert(namespace.operator,parameter);
    getSqlMapClientTemplate().insert(UserTest.insert,user);
       
}

对于多条件查询,ibatis有dynamic-mapped。这样可以构造动态的sql语句,而不需要去写多的判断极为方便。

xx.xml

< select  id ="select"  resutMap ="java.util.HashMap"  parameterClass ="java.util.HashMap" >
         select a*,u.use_name as userName  from advisor a ,user u left join a.advisorId = u.dataId
    
< dynamic  prepend ="where"   >
        
< isNotNull  prepend ="and"  property ="advisorName" >
        CONCAT(a.first_name,a.last_name) like #advisorName#
        
</ isNotNull >
        
< isNotNull  prepend ="and"  property ="countyId" >
         a.countyId = #countyId#
        
</ isNotNull >
        
< isNotNull  prepend ="and"  property ="qualification" >
        a.qualification = #qualification#
        
</ isNotNull >
    
</ dynamic >
</ select >

ibatis的“半自动”相对hibernate来说灵活性很大,使用起来也很方便。SqlMapClient类提供执行有mapped statement的API.

    还有更多有待研究。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值