一个经典的建模问题
来源:互联网 发布:js中event.target 编辑:程序博客网 时间:2024/05/17 04:42
我们在建模时最常见的关系是one-to-one,one-to-many,many-to-one等,最近我注意到一个问题,就是两个实体同时存在one-to-many与one-to-one关系,而且这种两种关系也是有联系的,那会产生什么样的问题呢?这就是我写这篇文章的目的
考虑这种一个场景:部门与员工的关系,一个部门有多个员工,一个员工属于一个部门,这是双向one-to-many关系;同时部门中有个员工为主管,且一个员工只能为一个部门的主管。这是one-to-one关系,而且这个one-to-one关系是以前面那个one-to-many为基础的。
这里我提供几种建模方式作为讨论:
第一种,最简单的方式,建立隐式的one-to-one的关系,这种方式的缺点,不好做O-R映射,至少,我目前还想不到怎么用hibernate annotation来实现。
第二种,通过一个中间表来建立one-to-one关系,与第一种比,这个好写O-R映射文件,不过,从数据建模的角度看,没有体现出one-to-one的关系是建立在one-to-many基础之上,这只能由程序员在编程代码中来实现,尤其是,若想获得某个部门的所有员工时,就要查询两张表
第三种,与第二种相似,就是把部门主管表改为部门员工表,第二种方式以已部门为中心,这种方式以员工为中心,而且这种方式与第二种比较会有较大性能损失,尤其在部门员工数比较多的时候
第四种,就是在部门中建一个指向员工表的外键(“主管”),这种方式有个缺点,就是在生成数据库时,会产生“鸡生蛋”与“蛋生鸡”的问题。而且,我一直认为这种问题在数据建模时,应该严格避免的
我自己目前采用第二种方式,大家可以讨论哪种方式比较好
- 一个经典的建模问题
- 一个经典的问题
- 一个比较经典的问题
- 一个经典问题的理解
- [全程建模]几个建模问题的回答
- 一个sql语句的经典问题,求解!
- OpenGL一个经典问题的解决办法
- 一个经典的进程调度问题
- 趣题:经典二分问题的一个扩展
- 一个经典的多线程同步问题
- 一个经典的java传递问题
- 一个经典的多线程同步问题
- 一个经典的n皇后问题
- 肤色建模的一个示例
- 一个经典小问题
- 一个数学建模的目标规划问题:奥运会商圈规划问题
- 操作系统的一个经典问题 -- "生产者-消费者"问题
- 程序编写的建模问题
- 转载【UML轻松入门——用例】 - [系统分析与设计]
- 六.修改用户 EditUser.aspx
- 转载【UML轻松入门--动态建模】 - [系统分析与设计]
- C# 与EXCEL
- 数据类型和抽象数据类型
- 一个经典的建模问题
- [WebWork]学习笔记之(一) - [Java/J2EE]
- [ 永远的UNIX::UNIX技术资料的宝库 ]首页 > 应用技术 > 其它 > 正文SED 手册 - 2. 使用 sedhttp://phi.sinica.edu.tw aspac@phi.sinica.edu.tw (2001-07-29
- VC中利用多线程技术实现线程之间的通信
- 关于MD5的个性化使用--如何避免解密者通过MD5网站服务对MD5解密
- 进程间通信的11种方法
- SD2.0大会归来
- 学会包容、善待他人
- 页面定时刷新