ibatis使用总结

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

ibatis使用总结

SqlMap的配置是iBatis中应用的核心。这部分任务占据了iBatis开发的70的工作量。

1、命名空间:

,在此空间外要引用此空间的元素,则需要加上命名空间名。

2、实体的别名:

如果有用到的全名的地方,可以用别名代替,受命名空间约束。

3、插入操作

对于自增主键的表,插入可以不配置插入的主键列。否则是必须的。

4、获取主键

插入语句之前配置:主要是针对Sequence主键而言,插入前必须指定一个主键值给要插入的记录。Oracle、DB2亦如此,方法是在插入语句标签之前配置上:

SELECT SEQ_TEST.NEXTVAL FROM DUAL

insert into .... ........

插入语句之后配置:主要是针对自增主键的表而言,这类表在插入时不需要主键,而是在插入过程自动获取一个自增的主键。比如MySQL

SELECT LAST_INSERT_ID()

insert into .... ........

当然,是否需要配置根据情况,只要能保证记录有主键即可。一旦配置了,就可以在执行插入操作时获取到新增记录的主键。

6、SQL入参parameterClass

插入语句入参:parameterClass="类别名" 来设定。

查询语句入参:可以设定类别名,也可以设定为map,也可以设定为iBatis支持的原生类型(比如string、int、long等),当只有一个原生类型入参时,使用#value#来引用,这个value 是不是关键字,可变。比如:

map是最强大的入参方式,任何入参方式都可以转换为这种入参方式,因为iBatis仅接受一个入参,当几个参数分布在不同对象中的时候,将这些对象的属性(或者对象本身put)到map中,然后一次传递给sql语句是非常有效。可以自己写一个将对象或者对象集合转换为map的工具(我已经实现一个了)。

另外,map的中的元素(比如pobj)是个复杂对象,则还可以在SQL中以#pobj.protyename#的格式来引用其中内嵌的属性。当然不推荐这么干。

7、返回值参数类型

返回值参数也同样有两种类型,一种是对象类型resultClass="Account",一种是resultMap="AccountResult"。这两种类型的选择常常会令人迷惑不解,一言明其理:

当结果集列名和类属性名完全对应的时候,则应该使用resultClass来指定查询结果类型。当然有些列明不对应,可以在sql中使用as重命名达到一致的效果。

当查询结果列名和类属性名对应不上的时候,应该选择resultMap指定查询结果集类型。否则,则查询出来填充的对象属性为空(数字的为0,对象的为null)。

但是实际上resultMap是对一个Java Bean的映射,需要先定义xml的映射后,才可以引用,例如:

resultMap映射的结果的目的就是要将查询的结果集绑定到映射对象的属性上。

不管使用哪种返回值参数类型,其最终目的就是要把每条记录映射到一个类的对象或者对象集合上,如果有某个类属性映射不上,则在得到的这个对象或对象集合中这个属性为空。映射的属性可以是表与实体中的一部分。不要同时使用两种返回值参数类型,这样只会令人迷惑。

8、查询结果集分组

查询结果集排序有两种方式:一是在结果集映射上定义,另一种就是在SQL语句中分组。建议在SQL语句中分组,以获得更大的可控制性。

9、SQL中参数的引用

SQL中引用parameterClass的参数有三种方式:

iBatis内置支持的类型,比如int、string,使用#value#来引用,这个value是不是关键字,可变。

map类型的参数,使用#keyName#来引用,keyName为键名。

复杂对象的参数,使用#propertyName#来引用,propertyName类属性的名字。

相关文档
最新文档