博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
.net使用NHibernate设置一对多、多对一关系
阅读量:6301 次
发布时间:2019-06-22

本文共 2224 字,大约阅读时间需要 7 分钟。

hot3.png

新入职一个公司,有一个功能模块需要修改,看了一个离职同事代码,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://my.oschina.net/u/3141521/blog/3053086

你可能感兴趣的文章
【高级数据类型】- 4.字典类型
查看>>
Myeclipse操作
查看>>
TextView动态设置图片
查看>>
Linux常用命令
查看>>
【83行代码获奖代码】高中生@青藤木子 耗费一周给妈妈编写了一款语音识别APP...
查看>>
安装PHP5、安装PHP7
查看>>
QuickBI助你成为分析师——搞定数据源
查看>>
关于vue路由跳转页面带参数方法总结
查看>>
推荐一个以动画效果显示github提交记录的黑科技工具:Gource
查看>>
数组的遍历及数组的去重
查看>>
轻量级内存计算引擎
查看>>
利用Rancher1.6部署K8s测试环境、开发环境
查看>>
Java反射在JVM的实现
查看>>
Google Java Style 中文版
查看>>
还在为测试发愁?10 个开源的压力/负载测试工具
查看>>
硬盘的原理以及SQL Server如何利用硬盘原理减少IO
查看>>
SpringMVC源码总结(九)HandlerMethodArgumentResolver介绍
查看>>
BAT等公司高薪招聘Android开发面试题目集锦
查看>>
SQL server 数据库的表的创建与使用T-SQL语句操控数据表
查看>>
你的孩子将来拿什么来跟人工智能竞争?
查看>>