数据表与简单java类映射转换
简单的Java类的定义来源于数据表的结构,
例如:雇员信息表、部门信息表描述的就是雇员或部门的信息,
在实际的开发之中,数据表和简单java类之间的映射关系如下:
1、 数据实体表设计 = 类的定义;
2、表中的字段 = 类的成员属性 ;
3、表的一行记录 = 类的一个实例化对象 ;
4、表的多行记录 = 对象数组 ;
5、表的外键关联 = 引用关联 ;
假设一个部门和雇员的表:
一个部门有多个雇员;
一个雇员属于一个部门;
一个雇员有一个领导;
下面将以上的数据表转为简单Java类的形式,
一、现要根据部门信息获取以下数据:
1、一个部门的完整信息;
2、一个部门之中所有雇员的完整信息;
3、一个雇员对应的领导的信息;
二、根据雇员信息获得以下内容:
1.一个雇员所在的部门信息;
2.一个雇员对应的领导信息;
第一步:抛开所有的关联字段不看,写出类的基本组成,而后通过引用配置关联字段的关系
package Mapping_transformation; class Demp
{
private long deptno ;
private String dname ;
private String loc ;
public Demp(long deptno , String dname ,String loc)
{
this.deptno = deptno ;
this.dname = dname ;
this.loc = loc ;
}
//setter、getter、无参构造略
public String getInfo()
{
return "【部门信息】部门编号:"+this.deptno+"、部门名称:"+this.dname +"、部门位置:"+this.loc ;
} }
class Emp
{
private long empno ;
private String ename ;
private String job ;
private double sal ;
private double comm ;
public Emp(long 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、getter、无参构造略
public String getInfo()
{
return "【雇员信息】雇员编号:"+this.empno + "、雇员姓名:"+this.ename + "、雇员工作:"+
this.job + "、雇员薪水:"+this.sal + "、雇员佣金"+this.comm ;
} }
第二步:配置所有的关联字段
package Mapping_transformation; class Dept
{
private long deptno ;
private String dname ;
private String loc ;
private Emp emps[] ; //多个雇员信息
public Dept(long deptno , String dname ,String loc)
{
this.deptno = deptno ;
this.dname = dname ;
this.loc = loc ;
} public void setEmps(Emp[] emps) {
this.emps = emps;
}
public Emp[] getEmps()
{
return this.emps ;
}
//setter、getter、无参构造略
public String getInfo()
{
return "【部门信息】部门编号:"+this.deptno+"、部门名称:"+this.dname +"、部门位置:"+this.loc ;
} }
class Emp
{
private long empno ;
private String ename ;
private String job ;
private double sal ;
private double comm ;
private Dept dept ; //所属部门
private Emp mgr ; //所属领导
public Emp(long 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、getter、无参构造略
public String getInfo()
{
return "【雇员信息】雇员编号:"+this.empno + "、雇员姓名:"+this.ename + "、雇员工作:"+
this.job + "、雇员薪水:"+this.sal + "、雇员佣金"+this.comm ;
} public void setDept(Dept dept) {
this.dept = dept;
} public void setMgr(Emp mgr) {
this.mgr = mgr;
} public Dept getDept()
{
return this.dept ;
}
public Emp getMgr()
{
return this.mgr ;
} }
第三步:根据关系进行类的定义,为对象进行关联的设置
public class Demo {
public static void main(String[] args) {
Dept dept = new Dept(10,"财务部","长沙");
Emp empA = new Emp(001,"A","java工程师",800.00,0.0);
Emp empB = new Emp(002,"B","经理",1000.00,0.0);
Emp empC = new Emp(003,"C","boss",1200.00,0.0); empA.setDept(dept);
empB.setDept(dept); //设置雇员与部门的关联
empC.setDept(dept); empA.setMgr(empB); //设置雇员与领导的关联
empB.setMgr(empC); dept.setEmps(new Emp[]{empA,empB,empC}); //部门与雇员
}
}
最后:获取数据所需数据
System.out.println(dept.getInfo()+"\n"); //部门信息
for(int i = 0 ; i < dept.getEmps().length ; i++)
{
System.out.println(dept.getEmps()[i].getInfo()); //雇员信息
if(dept.getEmps()[i].getMgr()!=null)
System.out.println(dept.getEmps()[i].getMgr().getInfo()); //雇员的领导信息
System.out.println();
}
System.out.println("------------------------------------------");
System.out.println(empA.getDept().getInfo()); //雇员获取部门信息
System.out.println(empA.getMgr().getInfo()); //雇员获取领导信息
【部门信息】部门编号:10、部门名称:财务部、部门位置:长沙
【雇员信息】雇员编号:1、雇员姓名:A、雇员工作:java工程师、雇员薪水:800.0、雇员佣金0.0
【雇员信息】雇员编号:2、雇员姓名:B、雇员工作:经理、雇员薪水:1000.0、雇员佣金0.0
【雇员信息】雇员编号:2、雇员姓名:B、雇员工作:经理、雇员薪水:1000.0、雇员佣金0.0
【雇员信息】雇员编号:3、雇员姓名:C、雇员工作:boss、雇员薪水:1200.0、雇员佣金0.0
【雇员信息】雇员编号:3、雇员姓名:C、雇员工作:boss、雇员薪水:1200.0、雇员佣金0.0
------------------------------------------
【部门信息】部门编号:10、部门名称:财务部、部门位置:长沙
【雇员信息】雇员编号:2、雇员姓名:B、雇员工作:经理、雇员薪水:1000.0、雇员佣金0.0
数据表与简单java类映射转换的更多相关文章
- Java基础_0311: 数据表与简单Java类映射
数据表与简单Java类映射 现在假设有如下的关系表,现在要求实现如下的数据关联操作: 一个部门有多个雇员: 一个雇员有一个或零个领导 代码实现 class Dept { private int dep ...
- 菜鸡的Java笔记 数据表与简单java类映射
利用实际的数据表实现表与类的操作转换 简单java类是整个项目开发中的灵魂所在,它有自己严格的开发标准,而最为重要的是它需要于数据表是完全对应的 不过考虑到现在没有接触到过 ...
- 数据表与简单java类——多对多映射
给定一张Meber和Product表,得到如下信息: 1.获取一个用户访问的所有商品信息 2.获取一个商品被哪些用户浏览过的信息 package Mapping_transformation; cla ...
- 数据表与简单java类——一对多映射
例如:给定一个分类表和子分类表 得到如下信息: 1.一个分类的完整信息: 2.根据分类获取其对应的子分类 package Mapping_transformation; class item { pr ...
- hibernate中.hbm.xml和注解方式自动生成数据表的简单实例(由新手小白编写,仅适用新手小白)
绝逼新手小白,so 请大神指点! 如果真的错的太多,错的太离谱,错的误导了其他小伙伴,还望大神请勿喷,大神请担待,大神请高抬贵嘴......谢谢. 好了,正题 刚接触ssh,今天在搞使用.hbm.xm ...
- mysql数据库和数据表的简单操作
一.数据库的增删改查 1.新建数据库 CREATE DATABASE 数据库名 charset utf8; 数据库名规则:可以由字母.数字.下划线.@.#.$ 区分大小写, 不能使用关键字如 crea ...
- 数据表-java类的映射
1.一个数据表对应一个java类 2.数据表的字段对应java类的属性 3.一对多的数据表关系 一方用一个java对象表示 多方用一个java对象数组表示 4.多对多的数据表关系:采用中间表,将多对多 ...
- KETTLE——(例)简单的字段转换
一个简单的小例子:结合数据抽取.简单的字段转换.数据输出. 资源库连接.数据输入.数据输出.参见之前的文章. 基本的转换结构是这样的,我们从表中输入,选择我们需要的字段,已经对应的名称,然后将数据 ...
- 以对象的方式来访问xml数据表(二)
为什么要以对象的方式来访问xml数据表? 还记得,自己是在一次完成师兄布置的任务时接触到了xml,那时候需要用xml来作为数据文件,保存一个简单的图书管理系统的数据.于是就知道了,可以用xml文件来保 ...
随机推荐
- vue 列表的排序过渡 shuffle遇到的问题
内部的实现,Vue 使用了一个叫 FLIP 简单的动画队列使用 transforms 将元素从之前的位置平滑过渡新的位置 需要注意的是使用 FLIP 过渡的元素不能设置为 display: inlin ...
- C语言知识体系
吾尝终日而思矣,不如须臾之所学也: 吾尝跂而望矣,不如登高之博见也. 登高而招,臂非加长也,而见者远: 顺风而呼,声非加疾也,而闻者彰. 假舆马者,非利足也,而致千里: 假舟楫者,非能水也,而绝江河. ...
- Go netpoll I/O 多路复用构建原生网络模型之源码深度解析
导言 Go 基于 I/O multiplexing 和 goroutine 构建了一个简洁而高性能的原生网络模型(基于 Go 的I/O 多路复用 netpoll),提供了 goroutine-per- ...
- CSPS模拟 50
收获很多,良心出题人 T1 施工 研究半天,最后30分暴力走人 考后看了题解,稍神仙这题弃对了...... 要拿30+,必须发现要填的话一定是填一个坑使它底部变平,最终底部高度小于等于两边 为什么是坑 ...
- Java Stream函数式编程第三篇:管道流结果处理
一.Java Stream管道数据处理操作 在本号之前写过的文章中,曾经给大家介绍过 Java Stream管道流是用于简化集合类元素处理的java API.在使用的过程中分为三个阶段.在开始本文之前 ...
- 通俗易懂了解Vue组件的生命周期
1.前言 在使用vue2.0进行日常开发中,我们总有这样的需求,我就想在页面刚一加载出这个表格组件时就发送请求去后台拉取数据,亦或者我想在组件加载前显示个loading图,当组件加载出来就让这个loa ...
- [转载]1.1 UiPath下载安装与激活
一.UiPath下载 1.打开官网https://www.uipath.com.cn,点击开始试用 2.选择获取UiPath社区版 3.填写姓.名.电子邮箱地址.专业领域.职位.公司.公司所在行业.国 ...
- 012.Kubernetes二进制部署worker节点Flannel
一 部署flannel 1.1 安装flannel kubernetes 要求集群内各节点(包括 master 节点)能通过 Pod 网段互联互通.flannel 使用 vxlan 技术为各节点创建一 ...
- 从EFCore上下文的使用到深入剖析DI的生命周期最后实现自动属性注入
故事背景 最近在把自己的一个老项目从Framework迁移到.Net Core 3.0,数据访问这块选择的是EFCore+Mysql.使用EF的话不可避免要和DbContext打交道,在Core中的常 ...
- 理解Spark运行模式(二)(Yarn Cluster)
上一篇说到Spark的yarn client运行模式,它与yarn cluster模式的主要区别就是前者Driver是运行在客户端,后者Driver是运行在yarn集群中.yarn client模式一 ...