实战:数据表与简单Java类映射

要求:用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());
            }
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值