您好,登錄后才能下訂單哦!
這篇文章主要介紹“Java實體類中Set怎么按照對象的某個字段對set排序”,在日常操作中,相信很多人在Java實體類中Set怎么按照對象的某個字段對set排序問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java實體類中Set怎么按照對象的某個字段對set排序”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
背景:
User實體類 有個屬性是 Set<PositionChange> 職位變更字段
如下:
PositionChange實體類 有個屬性是positionStartDate 什么時候開始任職此職務的字段
現在有一個需求,想在查詢出 User這個對象的時候 ,可以獲取到 Set<PositionChange>中 用戶最新任職的一條崗位記錄,也就是展示當前用戶所處的崗位信息。
但是,Set始終的無序的,想要取出Set中PositionChange的positionStartDate時間最新的一條,并且是在 取出User的時候 直接就是好的 我直接拿來用就行了
需求介紹完畢
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
解決途徑: 在User實體中 新設置一個List<PositionChange> 用來裝將Set按照自己的想法排序之后的結果
在使用的地方 直接取List里面的值即可。
import java.sql.Timestamp;import java.util.ArrayList;import java.util.Collections;import java.util.Comparator;import java.util.HashSet;import java.util.List;import java.util.Set;/*** User 用戶*/@Entity@Table(name = "user", catalog = "performance")@JsonIgnoreProperties(value={"workaffs"})public class User implements java.io.Serializable {private Set<Positionchange> positionchanges = new HashSet<Positionchange>(0);//崗位變動表private List<Positionchange> positionChanges ;//新設置的List<>//不讓hibernate認為這是數據庫的字段@Transientpublic List<Positionchange> getPositionChanges() {positionChanges = new ArrayList<Positionchange>(positionchanges);Collections.sort(positionChanges, new Comparator<Positionchange>() {@Overridepublic int compare(Positionchange o1, Positionchange o2) {return o1.getPositionStartDate().after(o2.getPositionStartDate()) ? -1 : 1;}});return positionChanges;}public void setPositionChanges(List<Positionchange> positionChanges) {this.positionChanges = positionChanges;}
到此,關于“Java實體類中Set怎么按照對象的某個字段對set排序”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。