在查询对象的Set或Map成员时,您可以对其进行排序,排序可以在两个层次进行,一个是在Java执行环境中进行,一个是利用数据库本身的排序功能。
如果要在Java执行环境中进行排序,可以映像文件中设定sort属性,例如若为Set,则如下设定:
<set name="addrs" table="ADDRS" sort="natural">
<key column="USER_ID"/>
<element type="string" column="ADDRESS" not-null="true"/>
</set>
藉由指定sort为natural,Hibernate在加载数据库的数据时,将使用java.util.SortedSet型态对象,如果是String,则根据compareTo()方法来进行排序,上面的设定将会根据FILENAME进行排序。
如果是Map的话,则如下设定:
<map name="files" table="FILES" sort="natural">
<key column="USER_ID"/>
<index column="DESCRIPTION" type="string"/>
<element type="string" column="FILENAME" not-null="true"/>
</map>
上面的设定将使用java.util.SortedTree,根据DESCRIPTION进行排序,sort除了设定natural之外,也可以指定一个实现java.util.Comparator的类别名称。
以上的说明都是在查询数据时使用,User类别的属性成员撰写时可以是Map或Set型态,注意当设定sort="natural",并想要进行数据储存时,User类别的属性成员也必须更改为SortedMap或SortedSet型态,例如java.util.TreeMap或 java.util.TreeSet,否则会发生ClassCastException。
如果是利用数据库本身的排序功能,则使用order-by设定排序的方式,Hibernate会使用SQL语句在数据库中进行排序,例如在Set中是这么设定的:
<set name="addrs" table="ADDRS" order-by="ADDRESS desc">
<key column="USER_ID"/>
<element type="string" column="ADDRESS" not-null="true"/>
</set>
在Map中也是相同的设定方式,您也可以利用数据库中的函式功能,例如:
<map name="files" table="FILES" order-by="lower(FILENAME)">
<key column="USER_ID"/>
<index column="DESCRIPTION" type="string"/>
<element type="string" column="FILENAME" not-null="true"/>
</map>
使用这个方法进行排序时,Hibernate会使用LinkedHashSet或LinkedHashMap实现查询时的排序,所以这个方法仅适用于JDK 1.4或以上的版本。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/chunkyo/archive/2006/04/12/660101.aspx
Father --->Son
Father 对Son类是一对多的关系
Father
import java.util.Set; public class Father { private Long id; private String name; private Set<Son> sons; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Set<Son> getSons() { return sons; } public void setSons(Set<Son> sons) { this.sons = sons; } }
对应的hbm
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" > <hibernate-mapping package="com.bladwin.model"> <class name="Father" table="father"> <id name="id" column="father_id"> <generator class="native"/> </id> <property name="name" not-null="true" length="32"/> <set name="sons" cascade="all" inverse="true" lazy="true" sort="natural"> <key column="father_id"></key> <one-to-many class="Son"/> </set> </class> </hibernate-mapping>
Son
import org.apache.commons.lang.builder.CompareToBuilder; import org.apache.commons.lang.builder.EqualsBuilder; import org.apache.commons.lang.builder.HashCodeBuilder; import org.apache.commons.lang.builder.ToStringBuilder; import org.apache.commons.lang.builder.ToStringStyle; //这里要继承Comparable接口 public class Son implements Comparable{ private Long id; private String name; private int age; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String toString(){ return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) .append(this.id) .append(this.name) .toString(); } public boolean equals(Object o){ Son s=(Son)o; return new EqualsBuilder().append(this.id, s.id) .append(this.name, s.name) .isEquals(); } public int hashCode(){ return new HashCodeBuilder().append(this.id) .append(this.name) .toHashCode(); } @Override public int compareTo(Object arg0) { Son s=(Son)arg0; return new CompareToBuilder() .append(this.age, s.age) .toComparison(); } }
对应的HBM
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" > <hibernate-mapping package="com.bladwin.model"> <class name="Son" table="son"> <id name="id" column="son_id"> <generator class="native"/> </id> <property name="name" not-null="true" length="32"/> <property name="age" not-null="true" ></property> </class> </hibernate-mapping>
junit测试
Set set=new TreeSet(); Son s1=new Son(); s1.setAge(30); s1.setName("ff"); set.add(s1); Son s2=new Son(); s2.setAge(20); s2.setName("dd"); set.add(s2); Son s3=new Son(); s3.setAge(10); s3.setName("rr"); set.add(s3); Father f1=new Father(); f1.setName("vv"); f1.setSons(set); fatherService.saveFather(f1); Set sr=new TreeSet(); sr=this.fatherService.getFather(1l).getSons(); Iterator it=sr.iterator(); while(it.hasNext()){ System.out.println(((Son)it.next()).getAge()); } }
输出是 10 20 30 是按年龄由小到大取的,在内存中派序