.net使用NHibernate设置一对多、多对一关系

新入职一个公司,有一个功能模块需要修改,看了一个离职同事代码,orm使用的是NHibernate,本身对EF还有NHibernate知道的不是很多,用的也不深。看到映射关系很头疼,实体类中嵌套各种实体类,不知道为什么,查了资料才知道,主要为了一对多、多对一的关系。下面是找的资料,让我明白了一些。

1.Fluent NHibernate让你不再需要去写NHibernate的标准映射文件(.hbm.xml), 方便了我们的代码重构,提供了代码的易读性,并精简了项目代码

实现:

(1)、首先我们通过nuget包管理器添加FluentNHibernate与NHibernate的引用。

(2)、编写实体类,注意实体的属性都是virtual//因为没使用过,但是来到公司以后才知道,不添加virtual操作实体类保存数据库会报错

(3)、实体类编写完成以后我们用代码的方式实现对实体的映射

2.定义支持的关联属性

Cascade 指该对象在进行操作时关联到的子对象的操作类型

PropertyRef属性一般用来解决遗留数据库一对多关系的问题

PropertyRef被关联到此外键的类中的对应属性的名字,若没指定,使用被关联类的主键.

PropertyRef不是数据库表中的字段名,而是定义的类中的属性名

3. 一对多HasMany<>() / 多对一 References<>()

3.1. 定义支持的关联属性

KeyColumn  表示主键名

Cascade表示级联取值,决定是否把对对象的改动反映到数据库中,所以Cascade对所有的关联关系都起作用, Cascade是操作上的连锁反映,Cascade取值可能是以下:

AllDeleteOrphan       在关联对象失去宿主(解除父子关系)时,自动删除不属于父对象的子对象, 也支持级联删除和级联保存更新.

DeleteOrphan           删除所有和当前对象解除关联关系的对象        

All                 级联删除, 级联更新,但解除父子关系时不会自动删除子对象.

Delete                                  级联删除, 但不具备级联保存和更新

None                                     所有操作均不进行级联操作

SaveUpdate                        级联保存(load以后如果子对象发生了更新,也会级联更新). 在执行save/update/saveOrUpdate时进行关联操作,它不会级联删除

Inverse()    所描述的是对象之间关联关系的维护方式,作用是:是否将对集合对象的修改反映到数据库中。Inverse表示对集合对象的修改会被反映到数据库中;为了维持两个实体类(表)的关系,而添加的一些属性,该属性可能在两个实体类(表)或者在一个独立的表里面,这个要看这双方直接的对应关系了: 这里的维护指的是当主控方进行增删改查操作时,会同时对关联关系进行对应的更新,Inverse是操作上的连锁反映。

NotFound   指定外键引用的数据不存在时如何处理: ignore会将数据不存在作为关联到一个空对象(null)处理。

用户表

public UserMap() 

    Table("Users"); 
    Id(u => u.UserID).GeneratedBy.Identity() ; 
    Map(u => u.UserName); 
    Map(u => u.Password); 
    Map(u => u.CreateTime); 
    //一对一映射用户和用户信息表
    HasOne<UserDetail>(u => u.Detail).Cascade.All().Fetch.Select(); 
    //处理一对多关系的映射,一个User可以有多个订单,关联的数据表进行延迟加载,主键名为UserID,级联关系所有操作
    HasMany<Order>(u => u.Orders).Cascade.All().Inverse().KeyColumn("UserID")LazyLoad(); 
}

订单表

public OrderMap() 

    Table("Orders"); 
    Id(o => o.OrderID).GeneratedBy.Identity(); 
    Map(o => o.Price); 
    Map(o => o.State).CustomType<OrderState>(); 
    Map(o => o.Address); 
    Map(o => o.Coignee); 
    Map(o => o.CreateTime); 
    Map(o => o.Zip); 
    //处理多对一关系,多个Order可以属于一个User
    References<User>(o => o.User).Column("UserID").Not.LazyLoad().Not.Insert().Not.Update();  

注意:  关联的数据表进行懒加载,主键名为UserID,级联关系所有操作,cascade:All|delete|saveorUpdate,级联删除时需加上Inverse()

什么是级联更新?什么是级联删除?

A :父表(外键对应的主键表) B:引用表(定义外键的表)
B与A 做级联更新 当 A 表数据修改时,B表相应数据也跟着修改
B与A 做级联删除 当 A 表数据删除时,B表相应数据也跟着删除

附上链接,想看完整的这个地址:https://www.cnblogs.com/shy1766IT/p/4855176.html

 

转载于:https://my.oschina.net/u/3141521/blog/3053086

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值