要求:用Java程序描述出department-employee关系,使用如下字段:
- dept: deptno dname loc ;
- emp: empno ename job sal comm deptno mgr
在dept-emp表的关系中存在如下的关联:
- 一个部门有多个雇员
- 一个雇员有一个或零个领导
第一步:实现基本字段的转换
class Dept {
private int depno;
private String dname;
private String loc;
//setter , getter , 无参构造省略
public Dept(int depno , String dname , String loc) {
this.depno = depno;
this.dname = dename;
this.loc = loc;
}
public String getInfo() {
return "部门编号:" + this.depno + ", 名称:"
+ this.name + ", 位置:" + this.loc;
}
}
class Emp {
private int empno;
private String ename;
private String job;
private double sal;
private double comm;
private Dept dept;
//setter , getter , 无参构造省略
public Emp(int empno , String ename , String job , double sal, double comm) {
this.empno = empno;
this.ename = ename;
this.job = job;
this.sal = sal;
this.comm = comm;
}
public String getInfo() {
return "雇员编号: " + this.empno + ", 姓名:" + this.ename + ", 职位:"
+ this.job + ", 工资:" + this.sal + ", 佣金:" + this.comm;
}
}
第二步:建立联系
一个雇员属于一个部门,应该在雇员里面保存部门信息
|- Emp类
public void setDept(Dept dept) {
this.dept = dept;
}
public Dept getDept() {
return this.dept;
}
一个部门有多个雇员,如果要描述多个这个概念应该使用数组来完成, 修改Dept类
private Emp[] emps; //多个雇员
public void setEmps(Emp[] emps) {
this.emps = emps;
}
public Emp[] getEmps() {
return this.emps;
}
一个雇员有一个领导:
private Emp mgr;
public void setMgr(Emp mgr){
this.mgr = mgr;
}
public Emp getMgr() {
return this.mgr;
}
第三步:设置并取得数据
对于这种映射的方式一定要分两步完成,第一,根据结构设置数据,第二,根据结构取出数据。
- 设置数据
public class Dept_emp {
public static void main(String[] args) {
//第一步:设置数据
//1、产生各自的独立对象
Dept dept = new Dept(10 , "ACCOUNTING" , "New York"); //部门信息
Emp ea = new Emp(7379 , "SMITH" , "CLERK" , 800.0 , 0.0); //雇员信息
Emp eb = new Emp(7369 , "FORD" , "MANAGER" , 2450.0 , 0.0); //雇员信息
Emp ec = new Emp(7359 , "KING" , "PRESIDENT" , 5000.0 , 0.0); //雇员信息
//设置雇员和领导关系
ea.setMgr(eb);
eb.setMgr(ec);
//设置雇员和部门关系
ea.setDept(dept);
eb.setDept(dept);
ec.setDept(dept);
dept.setEmps(new Emp[]{ea, eb, ec});
}
}
- 取出数据,根据给定结构取出数据,要求如下:
· 可以根据一个雇员查询他所对应的领导信息和部门信息;
· 可以根据一个部门取出所有的雇员以及每个雇员领导信息。
//第二步:取出数据
System.out.println(ea.getInfo());
System.out.println("\t|-" + ea.getMgr().getInfo());
System.out.println("\t|-" + ea.getDept().getInfo());
System.out.println(dept.getInfo());
for(int x = 0 ; x < dept.getEmps().length ; x++) {
System.out.println("\t|-" + dept.getEmps()[x].getInfo());
if(dept.getEmps()[x].getMgr() != null){
System.out.println("\t\t|-" +dept.getEmps()[x].getMgr().getInfo());
}
}