我想知道是否可以将 Set 成员添加为类的成员变量,然后可以将其对象作为值放入 Map。
我的想法是HashSet<T> projects
用作我的员工类的成员变量。但是,我想在数据库上执行一个查询,它将查询结果作为 Map> 项返回,其中 int 将是employeeId,而 Set 将是项目。这完全可行吗?
我想知道是否可以将 Set 成员添加为类的成员变量,然后可以将其对象作为值放入 Map。
我的想法是HashSet<T> projects
用作我的员工类的成员变量。但是,我想在数据库上执行一个查询,它将查询结果作为 Map> 项返回,其中 int 将是employeeId,而 Set 将是项目。这完全可行吗?
这绝对是可行的。看起来您正在实现员工和项目之间的多对多关系。这将对应于一对带有连接表的表来连接它们。
您将阅读您的员工和您的项目,然后将项目添加到每个员工集。
我应该提一下,将集合公开为成员变量并不是一个好主意,因为集合是可变的。您可以将变量设为私有,并公开方法以从您的对象添加/查询项目。
尝试这样的事情
class Project{
int pid;
int name;
//Getter and setter
}
创建员工类
public class Employee {
int employeeId;
String name;
Set<Project> projects;
//getter , setter or add methods
}
现在您可以在 DAO 中使用以上两个类
public class EmployeesDao{
/* Get multiple employee-projects */
public Map<Integer, Set<Project>> getManyEmployeeAndProjects(){
Map<Integer, Set<Project>> emps = new HashMap<Integer, Set<Project>>();
//query and populate
return emps;
}
/**
* Get single employee
*/
public Employee getEmployee(){
//Query and return Employee
return new Employee();
}
}
话虽如此,我认为您可能只需要返回员工列表,因为员工将拥有员工 ID 和项目
public List<Employee> getEmployees(){
//create list of Employee object
}