实战:数据表与简单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());
            }
        }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容