EF 关系描述
网络上常常看到有ef 1对1 1对多等关系的描述,按照我的理解,其根本就是为了呈现出一个视图,我最近设计了一个ef关系,请大家看一看。
需求描述
在gps车辆信息管理中,有个开户需求,其根本就是三种关系的对应,车辆信息,sim卡信息,以及终端信息,这三个实体是一一对应的,一旦开户,就需要三种信息。
先设计三种关系实体
/// <summary>
/// 实体模型抽象类
/// </summary>
public abstract class DbSetBase : IDbSetBase
{
/// <summary>
/// 构造函数
/// </summary>
public DbSetBase()
{
Id = Guid.NewGuid();
CreatedDate = DateTime.Now;
Deleted = false;
}
/// <summary>
/// 唯一Id
/// </summary>
[Key, DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public Guid Id { get; set; }
/// <summary>
/// 创建时间
/// </summary>
public DateTime CreatedDate { get; set; }
/// <summary>
/// 更新时间
/// </summary>
public DateTime? UpdatedDate { get; set; }
/// <summary>
/// 是否删除
/// </summary>
public bool Deleted { get; set; }
/// <summary>
/// 备注
/// </summary>
public string Remark { get; set; }
}
/// <summary>
/// 车辆数据
/// </summary>
[Table("S_VehicleInfo")]
public class VehicleInfo : DbSetBase
{
/// <summary>
/// 车牌号
/// </summary>
public string VehicleNo { get; set; }
/// <summary>
/// 车牌颜色
/// </summary>
public VehicleColor Color { get; set; }
/// <summary>
/// 企业信息
/// </summary>
public Guid EnterpriseId { get; set; }
/// <summary>
/// 企业信息
/// </summary>
[ForeignKey("EnterpriseId")]
public virtual Enterprise Enterprise { get; set; }
/// <summary>
/// 使用状态
/// </summary>
public UsingType UsingType { get; set; }
/// <summary>
/// 开户信息
/// </summary>
public virtual OpenAccount Account { get; set; }
/// <summary>
/// 所属车队
/// </summary>
public Guid? CompanyId { get; set; }
/// <summary>
/// 所属车队
/// </summary>
[ForeignKey("CompanyId")]
public virtual Company Company { get; set; }
}
/// <summary>
/// 终端信息
/// </summary>
[Table("S_TerminalInfo")]
public class TerminalInfo : DbSetBase
{
/// <summary>
/// 终端Id
/// </summary>
public string TerminalNo { get; set; }
/// <summary>
/// 终端类型
/// </summary>
public string TerminalType { get; set; }
/// <summary>
/// 使用状态
/// </summary>
public UsingType UsingType { get; set; }
/// <summary>
/// 开户信息
/// </summary>
public virtual OpenAccount Account { get; set; }
}
/// <summary>
/// Sim信息
/// </summary>
[Table("S_SimInfo")]
public class SimInfo : DbSetBase
{
/// <summary>
/// 手机号
/// </summary>
public string PhoneNo { get; set; }
/// <summary>
/// Sim卡号
/// </summary>
public string SimNo { get; set; }
/// <summary>
/// 使用状态
/// </summary>
public UsingType UsingType { get; set; }
/// <summary>
/// 开户信息
/// </summary>
public virtual OpenAccount Account { get; set; }
}
/// <summary>
/// 开户信息
/// </summary>
[Table("OpenAccount")]
public class OpenAccount : DbSetBase
{
/// <summary>
/// 终端信息
/// </summary>
public virtual TerminalInfo Terminal { get; set; }
/// <summary>
/// 车辆信息
/// </summary>
public virtual VehicleInfo Vehicle { get; set; }
/// <summary>
/// Sim信息
/// </summary>
public virtual SimInfo Sim { get; set; }
/// <summary>
/// 注册时间
/// </summary>
public DateTime? RegisterTime { get; set; }
/// <summary>
/// 是否注册
/// </summary>
public bool? IsRegister { get; set; }
}
}
,在通过 Fluent Api设计其对应关系:
modelBuilder.Entity<OpenAccount>().HasRequired(a => a.Vehicle).WithOptional(b => b.Account).Map(m => m.MapKey("VehicleId"));
modelBuilder.Entity<OpenAccount>().HasRequired(a => a.Sim).WithOptional(b => b.Account).Map(m => m.MapKey("SimId"));
modelBuilder.Entity<OpenAccount>().HasRequired(a => a.Terminal).WithOptional(b => b.Account).Map(m => m.MapKey("TerminalId"));
这样三种对象的对应关系就完成了,开户信息表就是作为一种视图来呈现三种对象的对应。
EF 关系描述的更多相关文章
- Oracle数据库表空间与数据文件的关系描述正确的是( )
Oracle数据库表空间与数据文件的关系描述正确的是( ) A.一个表空间只能对应一个数据文件 B.一个表空间可以对应多个数据文件 C.一个数据文件可以对应多个表空间 D.表空间与数据文件没任何对应关 ...
- EF 关系规则(一对一、一对多、多对多...)
转自: http://www.cnblogs.com/dudu/archive/2011/07/11/ef_one-to-one_one-to-many_many-to-many.html Entit ...
- EF里一对一、一对多、多对多关系的配置
EF关系规则 参考文章:http://www.cnblogs.com/feigao/p/4617442.html Entity Framework 实体间的关系,一对一,一对多,多对多,根据方向性来说 ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(24)-权限组的设计和实现(附源码)(终结)
ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 (2):数据库访问层的设计Demo (3):面向接口编程 (4 ):业务逻辑层的封装 ...
- 【EF 5】结合项目实战分析EF三大工作模式之—Database First
导读:所谓的EF的Databasefirst工作模式,是目前我们(不涉及社会领域)用的最广的一种模式,也是本次ITOO开发所采用的工作模式.本篇博客,就分析在项目中通过Database First模式 ...
- Entity Framework 实践系列 —— 搞好关系 - 两情相悦(双向一对一)【转载】
Entity Framework 实践系列 —— 搞好关系 - 两情相悦(双向一对一) 自从搞好了单向一对一关系,装满代码的心中塞进了挥之不去的情丝 —— 单相思.谁都知道音乐世界离不开情感,可谁又知 ...
- TOJ3660家庭关系(并查集+hash+图的连通性)
家庭关系 时间限制(普通/Java):1000MS/3000MS 运行内存限制:65536KByte 总提交: 38 测试通过: 9 描述 给定若干家庭成员之间的关系 ...
- [TYVJ] P1017 冗余关系
冗余关系 背景 Background 太原成成中学第3次模拟赛 第4题 描述 Description Mrs.Chen是一个很认真很称职的语文老师 ......所以,当她看到学生作文里的人物关系描 ...
- UML总结4---UML九种图关系说明
转自:http://blog.csdn.NET/chenyujing1234/article/details/8173519 UML中包括九种图:用例图.类图.对象图.状态图.时序图.协作图.活动图. ...
随机推荐
- 常见的FPGA内串行数据采样的方式
总结下常见的对串行数据采样的三种方式: 1. 全采样存储方式: 采用过采样,用过采样时钟,用移位寄存器移位,把每次采样值都存起来.采用高速的过采样时钟运行. 然后等待触发条件,(就是找到数据的起始点条 ...
- Signed comparison in Verilog
Signed comparison in Verilog¶ When you write this in Verilog: wire [7:0] a; wire [7:0] b; wire less; ...
- 你的Java代码对JIT编译友好么?(转)
JIT编译器是Java虚拟机(以下简称JVM)中效率最高并且最重要的组成部分之一.但是很多的程序并没有充分利用JIT的高性能优化能力,很多开发者甚至也并不清楚他们的程序有效利用JIT的程度. 在本文中 ...
- open-flash-chart2各种效果
<pre class="html" name="code"><pre class="html" name="co ...
- hdu1881 毕业bg(深搜索dfs)
主题链接:pid=1881">http://acm.hdu.edu.cn/showproblem.php? pid=1881 ----------------------------- ...
- 【iOS发展-70】点菜系统案例:使用文本框inputView和inputAccessoryView串联UIPickerView、UIDatePicker和UIToolBar
(1)效果 (2)先在storyboard中设计界面,然后源码(直接在ViewController中码) #import "ViewController.h" @interface ...
- 准备战争“软测试”之DB基础知识
"数据库"东西这个陌生和数据,进入提高班,从第二年开始接触,的项目还是自考的学习加起来也有3遍了.这仅仅是一个開始,软考又要对数据库进行全面的分析,那么如今就让我们再一次剖析它吧! ...
- NEFUOJ 500 二分法+最大流量
http://acm.nefu.edu.cn/JudgeOnline/problemshow.php?problem_id=500 description 在这个信息化的时代.网购成为了最流行的购物方 ...
- 数据库数据导出成XML文件
在数据库中,怎样把库中的数据导出XML文件, sql语句如下: SELECT * FROM 表名 FOR XML AUTO, ELEMENTS
- 安装ruby on rail
安装: # nvm 安装, 两种方法 $ curl https://raw.githubusercontent.com/creationix/nvm/v0.8.0/install.sh | sh $ ...