最近因项目要求学习了一下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 >
< 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);
}
... {
//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 >
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.
还有更多有待研究。