在one-to-many(parent/child)关系中, 不妨假设对应表为parent和child,对应的POJO(javabean)为Parent和Child。在Parent中会定义一个元素为Child对象的集合。在hibernate3.2版本上,该集合支持set/bag/array/list/map类型,其中以set最为常用。
1、set为无重复元素集合,而bag则允许元素有重复(bag对应的集合必须声明为List或Collection)
2、list和array需要一个索引字段,即表示该条记录在列表或数组中的顺序号
3、map需要一个key字段,value一般用普通类型(如String)或实体类(如本例中的Child类)
通过一个简单的范例程序,很好地比较了各种集合的使用方法,以及输出结果的差异。掌握了这几种集合的用法之后,再在实际项目中根据不同的需求进行选择。
在集合标签中,有2个属性必须得强调一下:
1、order-by表示集合元素的排列顺序,可以按照某个字段的升降序排列(seqno asc)
2、fetch="join|select|subselect",join表示用连接查询的方式同时取出Parent和child(即一条SQL语句),而select方式则表示先读取Parent,再根据parent_id来读取Child列表(发出二条SQL语句)。这两种方式在性能上有差别,当启用了延迟加载模式(lazy="true")后,比如查出1000个parent,而只想看其中10个parent对应的child列表,则select方式的性能会比join方式更好。
如用array或list来保存某书籍的作者列表(第一作者、第二作者)。
附件中为源代码程序(hibernate3.2,jdk5.0)
(因发帖时上传文件功能有bug无法上传文件,暂且将附件放到“我的资源”中)