這是我第一次使用 Java。我需要有關根據屬性唯一值將列表分配到列表中的幫助。我創建從SQL表稱為對象Student的屬性ID,NAME以及COUNTRYpackage Data;import java.util.ArrayList;import java.util.List;import Oracle.DBConnection;public class Students {public static void main(String[] args) { DBConnection.OpenConnection(); String query = "SELECT * FROM STUDENT ORDER BY COUNTRY"; Student[] students = DBConnection.ExecuteQuery(query); DBConnection.CloseConnection(); }}現在我有對象學生,有什么方法可以根據獨特的城市對學生對象進行分組并創建一個包含這些對象的列表?該列表將如下所示:List = [object1, object2, object3,etc]并且每個對象都有相同的記錄 COUNTRY提前致謝
1 回答

慕俠2389804
TA貢獻1719條經驗 獲得超6個贊
您應該查看地圖,更具體地說是查看地圖Map<String, Set<Student>>。您返回的數組應該已經排序,因為這是您在查詢中放置的內容,但是如果您想進一步組織和使用您的數據,您可以將此列表轉換為地圖,這是一種更有用的數據結構給你。
例如(在 Java 8 中)有這樣的東西:
List<Student> studentList = Arrays.asList(students);
Map<String, Set<Student>> mapByCountry = studentList.stream().collect(Collectors.groupingBy(student -> student.getCountry(), Collectors.toSet()));
(這是假設您的國家/地區字段是字符串)
現在,您只需詢問地圖即可訪問每個國家/地區的學生。
Set<Student> studentsInMyCountry = mapByCountry.get("TheBestCountryInTheWorld");
當然,也有一些方法可以像您要求的那樣將原始列表轉換為列表列表,但這將不太有用,因為那樣您仍然不知道子列表中的學生屬于哪個國家,除非再次進行評估。
添加回答
舉報
0/150
提交
取消