分享
 
 
 

O/RMAPPING(Hibernate)方法小结

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

一.对象之间的关系:

1.依赖:

依赖对象通过调用被依赖对象的方法来获得服务。一种比较松散的关系,并且是短期的。我们的过程与对象往往依赖于我们的实体域对象。如在struts的action中调用模型层的方法。

2.关联

它使一个类指到另一个类的属性。长期的

3.聚合

聚合关系是关联关系的一种,是强的关联关系。聚合是整体和部分之间的关系。

4.组合

也叫合成关系,组成关系是关联关系的一种,是比聚合关系强的关系。对象负责代表部分的对象的生命周期。

注:既然聚合,组合关系属于关联关系,那么如何区分一般关联关系,聚合关系和组合关系呢?

一般关联:只要一个对象联系到另外一个对象就形成了关联关系。如:人和他的猫,黑豹乐队和窦唯,PC机和显示器。

聚合关系:一种强关联关系,它要求有部分和整体的关系,并且没有了整体部分也可以独立存在。在上面三个例子中人和它的猫显然没有部分和整体的关系,所以只能是一般的关联关系。而黑豹乐队和窦唯,窦唯等人组成了黑豹乐队即:窦唯和黑豹是整体和部分的关系。

而窦唯脱离了黑豹(早就离开了)更或者黑豹不存在了那么窦唯仍然可以以音乐人的身份存在(即对象仍然可以独立存在)所以它属于聚合关系。组成关系是可以共享的。(窦唯也可以加入其他乐队)。

组合关系:一种更强的整体和部分的关系。它并且要求代表整体的对象负责代表部分的对象的生命周期,组成关系是不能共享的。如:PC机和显示器的关系。

我觉得:如果两个实体是整体和部分的关系,那么它们到底是聚合还是组合,这取决于你的需求。比如说:PC机和显示器的关系,如果你的系统中,显示器脱离了PC机就不存在意义了,也可以说:所有显示器的访问都是通过PC机进行的,那么你可以把关系设定为组合(如你在为一个只买品牌机的代理商作系统你可能是可以这么作的)。

如果你的显示器脱离的PC机仍然可以独立存在,也就是说在系统中可以直接访问显示器对象,那么你可以将关系设为聚合(如你在为一个买散件的代理商作系统你可能是可以这么作的)

5.继承

这个我不想多讲了,用过面向对象的语言都应该知道。

二.关系数据库的关系

一对一

一对多

多对一

多对多

三.o/r mapping策略

1.继承:

对于继承关系一般有三种策略:

策略1继承树的每个类对应一个表

<joined-subclass //共享主键

策略2继承树的根类对应一个表

<discriminator <subclass //需要添加一个识别字段

策略3继承树的叶子类对应一个表,不支持多态查询

2.关联

2.1 一对一

一半有两种策略:

策略1:唯一的外键

<many-to-one+unique="true" (唯一的外键)

<one-to-one

策略2:共享主键

<one-to-one

<one-to-one<constrained="true" //既是主键又是外键

注意:生成方式需要用:foreign

2.2 一对多(无需多说)

2.3 多对一(无需多说)

2.4 多对多

策略1:A,B表多对多的关系需要引入C表。

C表中的所有属性即为主键又为外键分别参照A,B两表。

C表中不可以有其他属性

策略2:将多对多拆分成两个一对多:

A,B对象多对多的关系需要引入C对象。使得A,B两对象与C对象的关系为一对多。对应数据库中:A,B表多对多的关系需要引入C表。A,B两表与C表的关系为一对多。

C表又自己的主键

C表中又非主键的外键分别参照A,B两表。

C表中不可以有其他属性

如;学生 ,课程为多对多的关系 那么引入学生选课。

注意:策略1和策略2的不同在于:策略2引入了新的对象而策略1没有。这是因为这样:策略1的c表不能又自己的东西。而策略2有。

2.5 其他

上面说过:聚合与组成是关联的一种所以他们也符合以上策略。

特别的:当用到组合关系的是否我们可用用到hibernate的"组件"

<component

由于"组件"它完全可以满足组成关系的强关联。

3.依赖

一般不在实体域对象中体现。

O/R MAPPING (HIBERNATE)方法小结 (补充内容):

另外我看到了一种"键关联"的方法,感觉很有道理。我理解了一下总结如下:

1.一般关联:

这种方法对于一般的关联总是引入c表(另外的一张表)仅仅表示关系。

C表的主键有分别指向A,B两表(外键)。当指向一方的外键unique="true"即唯一,那么这一方为"一",反之为"多"的一方。这样就可以形成一般的关联关系。但是注意的是:c表不映射为对象。C表也没有自己的属性。

2.聚合和组成

当实体A的非主键列中有一个引自实体B的时候,这种关系是B聚合A。如果这种引用是强制性的,则是合成关系,否则为聚合关系。是否为强制性,只需要将引用列设为非空即可;

3.继承

当实体A的主键引用自实体B的时候(即为外键),那么A继承 B。

总结:我觉得O/RM的方法有很多,我们可以看到"按外键"的方法思路很清晰。但是它在解决一般的关联的时候总是引入另外一张表这样势必影响效率。另外,既然聚合和组合是关联的一种那么即使是组合关系我也把它看成一般关联,也不算错的。

关系数据库一开始就不是为了面向对象的语言服务的,所以我们在这里映射无论那种方法似乎都不能说是完全的,正确无误完成了O/RM。所以我觉得一切都要看我们的项目需求。因地制宜!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有