容器的排序[Java编程]
本文“容器的排序[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
从资料库的概念来看,Set、Map、Bag是无序的,而List是有序的,这边所谓的无序或有序,是指将容器中物件储存至资料库时,能否依容器物件中的次序来储存.
但是从资料库获得资料之後,您大概会但愿Set、Map等容器中的物件可以依一定的次序来布列,您可以从两个层次来容器中的物件排序,一是在载入资料後於JVM中排序,另一是在资料库中直接利用order by子句来排序.
以 Set 这篇文章中的典范来作阐明,要在JVM中就资料举行排序,您可以在映射文件中利用sort属性来定义容器的排序,这实用於Set与Map,比方:
User.hbm.xml
<?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>
<class name="onlyfun.caterpillar.User" table="user">
....
<set name="emails" table="email" sort="natural">
<key column="id"/>
<element type="java.lang.String"
column="address"/>
</set>
</class>
</hibernate-mapping>
sort="natural"表示利用物件的comparaTo()办法来举行排序,容器中的物件上必须有实作java.lang.Comparable 介面,比方String就有实作java.lang.Comparable介面,后果会利用字典次序来布列容器中的物件.
您可以实现自己的排序方法,只要定义一个类别来实作java.util.Comparator介面,比方:
CustomComparator.java
package onlyfun.caterpillar;
import java.util.Comparator;
public class CustomComparator implements Comparator {
public int compare(Object o1, Object o2) {
if (((String) o1).equals(o2))
return 0;
return ((Comparable) o1).compareTo(o2) * -1;
}
}
以上是“容器的排序[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |