要进行关系设计,该数据表对应有如下的几个关系 一。 一个雇员属于一个部门,需要追加部门引用; 二。一个雇员有一个领导,领导一定是自身关联,自身引用 三。一个部门有多个雇员
//部门类class Dept{ private int deptno;//部门编号 private String dname;//部门名称 private String loc;//部门位置 private Emp emps[];//“引用关系” 多个雇员,描述多这个概念应该使用对象数组进行完成 //明确定义一个无参构造 public Dept(){ } public Dept(int deptno,String dname,String loc){//有参构造 this.deptno = deptno; this.dname = dname; this.loc = loc; } //setter方法 public void setDeptno(int d){ this.deptno = d; } public void setDname(String n){ this.dname = n; } public void setLoc(String l){ this.loc = l; } //对象数组的setter方法 public void setEmp(Emp[] e){ this.emps = e ; } //getter方法 public int getDeptno(){ return deptno; } public String getDname(){ return dname; } public String getLoc(){ return loc; } //对象数组的getter方法 public Emp[] getEmp(){ return emps; } //取得完整信息 public String getInfo(){ return "部门编号:" + this.deptno + ",名称:" + this.dname + ",位置:" + this.loc; } }//员工类class Emp{ private int empno; private String ename ; private String job ; private double sal; private double comm ; private Dept dept;//“引用关系” 在雇员里面保存部门信息 private Emp mgr;//“引用关系” 在雇员里面设置领导信息 public Emp(){//无参构造 } 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 ; } //setter方法 public void setEmpno(int e){ this.empno = e; } public void setEname(String n){ this.ename = n ; } public void setJob(String j){ this.job = j ; } public void setSal(double s){ this.sal = s ; } public void setComm(double c){ this.comm = c ; } public void setMgr(Emp m){ this.mgr = m; } public void setDept(Dept d){ this.dept = d; } //getter方法 public int getEmpno(){ return empno; } public String getEname(){ return ename; } public String getJbo(){ return job; } public double getSal(){ return sal; } public double getComm(){ return comm; } public Emp getMgr(){ return mgr; } public Dept getDept(){ return dept; } public String getInfo(){//取得完整信息 return "雇员编号:" + this.empno + ",姓名:" + this.ename + ",职位:" + this.job + ",工资:" + this.sal + ",佣金:" + this.comm ; } }//测试类,设置数据并取出public class TestDemo { public static void main(String[] args) { // 产生各自的独立对象,设置数据 Dept dept = new Dept(10,"ACCOUNTING","New York"); Emp ea = new Emp(1234,"Yiyao","CLERK",900.0,0.0); Emp eb = new Emp(1235,"Acan", "MANAGER",4000.0,9.0); Emp ec = new Emp(1236,"Dramatic","PRESIDENT",9000.0,80.0); //设置雇员和领导关系 ea.setMgr(eb); eb.setMgr(ec); //设置雇员和部门关系 ea.setDept(dept); eb.setDept(dept); ec.setDept(dept); //部门与雇员 dept.setEmp(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("-----------------------------------------");//分割线 System.out.println(dept.getInfo()); for(int x = 0; x < dept.getEmp().length; x++){ System.out.println("\t|-" + dept.getEmp()[x].getInfo()); if(dept.getEmp()[x].getMgr() != null){ System.out.println("\t\t|-" + dept.getEmp()[x].getMgr().getInfo()); } } } }
//部门类class Dept{ private int deptno;//部门编号 private String dname;//部门名称 private String loc;//部门位置 private Emp emps[];//“引用关系” 多个雇员,描述多这个概念应该使用对象数组进行完成 //明确定义一个无参构造 public Dept(){ } public Dept(int deptno,String dname,String loc){//有参构造 this.deptno = deptno; this.dname = dname; this.loc = loc; } //setter方法 public void setDeptno(int d){ this.deptno = d; } public void setDname(String n){ this.dname = n; } public void setLoc(String l){ this.loc = l; } //对象数组的setter方法 public void setEmp(Emp[] e){ this.emps = e ; } //getter方法 public int getDeptno(){ return deptno; } public String getDname(){ return dname; } public String getLoc(){ return loc; } //对象数组的getter方法 public Emp[] getEmp(){ return emps; } //取得完整信息 public String getInfo(){ return "部门编号:" + this.deptno + ",名称:" + this.dname + ",位置:" + this.loc; } }//员工类class Emp{ private int empno; private String ename ; private String job ; private double sal; private double comm ; private Dept dept;//“引用关系” 在雇员里面保存部门信息 private Emp mgr;//“引用关系” 在雇员里面设置领导信息 public Emp(){//无参构造 } 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 ; } //setter方法 public void setEmpno(int e){ this.empno = e; } public void setEname(String n){ this.ename = n ; } public void setJob(String j){ this.job = j ; } public void setSal(double s){ this.sal = s ; } public void setComm(double c){ this.comm = c ; } public void setMgr(Emp m){ this.mgr = m; } public void setDept(Dept d){ this.dept = d; } //getter方法 public int getEmpno(){ return empno; } public String getEname(){ return ename; } public String getJbo(){ return job; } public double getSal(){ return sal; } public double getComm(){ return comm; } public Emp getMgr(){ return mgr; } public Dept getDept(){ return dept; } public String getInfo(){//取得完整信息 return "雇员编号:" + this.empno + ",姓名:" + this.ename + ",职位:" + this.job + ",工资:" + this.sal + ",佣金:" + this.comm ; } }//测试类,设置数据并取出public class TestDemo { public static void main(String[] args) { // 产生各自的独立对象,设置数据 Dept dept = new Dept(10,"ACCOUNTING","New York"); Emp ea = new Emp(1234,"Yiyao","CLERK",900.0,0.0); Emp eb = new Emp(1235,"Acan", "MANAGER",4000.0,9.0); Emp ec = new Emp(1236,"Dramatic","PRESIDENT",9000.0,80.0); //设置雇员和领导关系 ea.setMgr(eb); eb.setMgr(ec); //设置雇员和部门关系 ea.setDept(dept); eb.setDept(dept); ec.setDept(dept); //部门与雇员 dept.setEmp(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("-----------------------------------------");//分割线 System.out.println(dept.getInfo()); for(int x = 0; x < dept.getEmp().length; x++){ System.out.println("\t|-" + dept.getEmp()[x].getInfo()); if(dept.getEmp()[x].getMgr() != null){ System.out.println("\t\t|-" + dept.getEmp()[x].getMgr().getInfo()); } } } }
相关文章:
Java 基础 byte[]与各种数据类型互相转换的简单示例
以上是数据表和简单的Java转换 _引用关系的实战案例的详细内容。更多信息请关注PHP中文网其他相关文章!

类加载器通过统一的类文件格式、动态加载、双亲委派模型和平台无关的字节码,确保Java程序在不同平台上的一致性和兼容性,实现平台独立性。

Java编译器生成的代码是平台无关的,但最终执行的代码是平台特定的。1.Java源代码编译成平台无关的字节码。2.JVM将字节码转换为特定平台的机器码,确保跨平台运行但性能可能不同。

多线程在现代编程中重要,因为它能提高程序的响应性和资源利用率,并处理复杂的并发任务。JVM通过线程映射、调度机制和同步锁机制,在不同操作系统上确保多线程的一致性和高效性。

Java的平台独立性是指编写的代码可以在任何安装了JVM的平台上运行,无需修改。1)Java源代码编译成字节码,2)字节码由JVM解释执行,3)JVM提供内存管理和垃圾回收功能,确保程序在不同操作系统上运行。

Javaapplicationscanindeedencounterplatform-specificissuesdespitetheJVM'sabstraction.Reasonsinclude:1)Nativecodeandlibraries,2)Operatingsystemdifferences,3)JVMimplementationvariations,and4)Hardwaredependencies.Tomitigatethese,developersshould:1)Conduc

云计算显着提升了Java的平台独立性。 1)Java代码编译为字节码,由JVM在不同操作系统上执行,确保跨平台运行。 2)使用Docker和Kubernetes部署Java应用,提高可移植性和可扩展性。

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

容器化技术如Docker增强而非替代Java的平台独立性。1)确保跨环境的一致性,2)管理依赖性,包括特定JVM版本,3)简化部署过程,使Java应用更具适应性和易管理性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver Mac版
视觉化网页开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中