类间关系映射为键值

    数据库表的约束决定了实体类关系中的关联和聚合。

    一对一、一对多的关联式通过在关联的某一方(一般在关联角色多重性>=1的一方)引用对方的OID,并根据关系的紧密程度为外键的字段加上非空以及唯一性的约束。在生成相关联的类实例时,可根据外键自动获取另一方的实例。多对多的关联需要创建关联表。关联表是统一的以OID作为主键,同时以关联角色双方的OID作为联合外键。

    数据库表之间主键外键关联映射的关系对象模型中存在着三种关系,分别是一对一、一对多、多对多。体现在数据库中分别是一个主键对应一个外键,一个主键对应多个外键,中间表(join table)。

  1. 一对一:这种情况可以直接映射成在对象之间保持一个应用关系,一个对象持有对另一个对象的应用。具体体现在对象中实现一个方法,该方法的返回值即它的一对一关联对象。如果这种关系是双向的,那么必须在两个对象中都实现这样一个方法,如果关系是单向的,那么由方向性决定在哪个对象中实现。
  2. 一对多:这种关系有两种类型,分别是关联association和聚合aggregation。对于关联,仍然体现为应用关系。不同的与一对一的是,一方对象持有的是一个集合的应用,该集合中的元素师多方对象,多对象持有的一方对象的应用。一方对象实现的方法的返回值是一个集合,集合中的元素师多方对象;多方对象实现的方法的返回值就是一方对象。当然可根据业务需求决定关系的方向性,从而决定在哪个对象中实现对应的方法。对于聚合,需要在一方对象中增加一个集合的属性,该集合中的元素为多方对象。同时一方对象的增、改、删、查也要加入相应的操作以实现多方对应的操作。而多方对象的实现可以根据实际需求来决定是否需要实现独立的增、改、删、查方法。
  3. 多对多:这种关系可以看作是一个双向的一对多,都把自己看作是一方,对方看成是多方。两个对象分别持有集合的应用,集合中的元素即为对方对象。如果将数据库的中间变映射成一个对象,那么可以将多对多关系的两个对象分别实现为对用中间表对象的一对多,即这两个对象都可以看作是一方,而中间变对象则看作是多方。从而利用一对多的实现方式去实现这种关系。
面向对象操作映射为数据库操作
ORM框架的一项重要工作就是将对数据库的操作封装成实体类的方法。其好处就在于封装了操作的细节,开发人员根本不用关心如何去链接数据库,如何发送SQL语句,如何去取各个字段,它只需要调用一个CRUD(create、read、update、delete)方法,该方法完成一些列的底层操作,返回的是一个构造好的对象,然后他就可以调用相应的get方法取得他所需要的字段的数值。
ORM的框架的方法也就是增、改、删、查等基本操作,而实体对象属性也是由数据库表中的字段所构成的。ORM框架在构造过程中,实际上把CRUD方法,根据对象属性与数据库表的映射字段转化为数据库操作的inset、select、update和delete等SQL语句。

事务管理
由于ORM框架封装了数据的存储操作,软件开发人员不能处理底层存储细节,没有利用数据库的事务管理机制的可能。可以通过两种方法解决这个问题:
一是采用独立的事务处理机制,不采用数据库本身的事务管理;
二是在映射对象中重载多个保存方法,仍然采用数据库的数据管理机制,使得某一个重载的方法可以提供给软件开发人员事务处理的能力。在Java语言中,可以有软件开发人员提供一个java.sql.Connection接口,将这个接口作为一个参数传给保存的方法,从而可以使得软件开发人员有手工控制事物的可能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值