【EF Code First】 一对一、一对多的多重关系配置
这里使用相册Album和图片Picture的关系做示例
1,Album与Picture最基本的关系是1-n(一个相册可以有多张图片)
这时Album、Picture实体类可以这么定义
/// <summary>
/// 相册
/// </summary>
public class Album
{
public int ID { get; set; }
/// <summary>
/// 标题
/// </summary>
public string Title { get; set; }
public DateTime CreateTime { get; set; }
/// <summary>
/// 拥有者
/// </summary>
public virtual User Owner { get; set; }
}
/// <summary>
/// 图片
/// </summary>
public class Picture
{
public long ID { get; set; } public string Title { get; set; } public string Uri { get; set; } public DateTime CreateTime { get; set; } /// <summary>
/// 所属相册
/// </summary>
public virtual Album Album { get; set; }
}
生成的表结构
2,后来就要改需求了,相册要加一个封面
于是Album与Picture的关系就加了一个1-1(一个相册只有一个封面)
这样就需要配置一下实体关系来区分属性之间的关系
Album和Picture类做一些修改
/// <summary>
/// 相册
/// </summary>
public class Album
{
public int ID { get; set; }
/// <summary>
/// 标题
/// </summary>
public string Title { get; set; }
public DateTime CreateTime { get; set; }
/// <summary>
/// 拥有者
/// </summary>
public virtual User Owner { get; set; }
/// <summary>
/// 封面
/// </summary>
public virtual Picture Cover { get; set; }
/// <summary>
/// 相册下的图片列表
/// </summary>
public virtual ICollection<Picture> Pictures { get; set; }
}
/// <summary>
/// 图片
/// </summary>
public class Picture
{
public long ID { get; set; } public string Title { get; set; } public string Uri { get; set; } public DateTime CreateTime { get; set; } /// <summary>
/// 所属相册
/// </summary>
public virtual Album Album { get; set; }
}
然后添加一个映射类
public class AlbumMap:EntityTypeConfiguration<Album>
{
public AlbumMap() {
this.HasMany<Picture>(a => a.Pictures).WithRequired(p=>p.Album);
}
}
EF上下文类中重写方法
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();//移除复数表名的契约
modelBuilder.Configurations.Add(new AlbumMap());
}
数据库迁移时生成的代码:
public partial class AlbumAddCover : DbMigration
{
public override void Up()
{
DropForeignKey("dbo.Picture", "Album_ID", "dbo.Album");
DropIndex("dbo.Picture", new[] { "Album_ID" });
AddColumn("dbo.Album", "Cover_ID", c => c.Long());
AlterColumn("dbo.Picture", "Album_ID", c => c.Int(nullable: false));
CreateIndex("dbo.Album", "Cover_ID");
CreateIndex("dbo.Picture", "Album_ID");
AddForeignKey("dbo.Album", "Cover_ID", "dbo.Picture", "ID");
AddForeignKey("dbo.Picture", "Album_ID", "dbo.Album", "ID", cascadeDelete: true);
} public override void Down()
{
DropForeignKey("dbo.Picture", "Album_ID", "dbo.Album");
DropForeignKey("dbo.Album", "Cover_ID", "dbo.Picture");
DropIndex("dbo.Picture", new[] { "Album_ID" });
DropIndex("dbo.Album", new[] { "Cover_ID" });
AlterColumn("dbo.Picture", "Album_ID", c => c.Int());
DropColumn("dbo.Album", "Cover_ID");
CreateIndex("dbo.Picture", "Album_ID");
AddForeignKey("dbo.Picture", "Album_ID", "dbo.Album", "ID");
}
}
最终表结构
上一节:【EF Code First】 一对多、多对多的多重关系配置
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------
【EF Code First】 一对一、一对多的多重关系配置的更多相关文章
- 【EF Code First】 一对多、多对多的多重关系配置
这里使用用户表(User)和项目(Project)表做示例 有这样一个需求: 用户与项目的关系是:一个用户可以发多个项目,可以参加多个项目,而项目可以有多个参与成员和一个发布者 [其中含1-n和n-n ...
- EF Code First一对一、一对多、多对多关联关系配置
1.EF Code First一对一关联关系 项目结构图: 实体类: Account.cs using System; using System.Collections.Generic; using ...
- EntityFrameworkCore 一对一 && 一对多 && 多对多配置
基本数据结构 表设计如下: 入学记录 public class AdmissionRecord { [Key] public long Id { get; set; } public DateTime ...
- EF Code First中的主外键约定和一对一、一对多关系的实现
对于主外键约定的理解,其实是学习实体间一对一和一对多关系的基础. 1.1 主键(Key)约定 主键的默认约定是:只要字段名为--实体名(类名)+"id"(不区分大小写),这就算是默 ...
- EF Code First 一对多、多对多关联,如何加载子集合?
应用场景 先简单描述一下标题的意思:使用 EF Code First 映射配置 Entity 之间的关系,可能是一对多关系,也可能是多对多关系,那如何加载 Entity 下关联的 ICollectio ...
- EF Code First学习系列
EF Model First在实际工作中基本用不到,前段时间学了一下,大概的了解一下.现在开始学习Code First这种方式.这也是在实际工作中用到最多的方式. 下面先给出一些目录: 1.什么是Co ...
- EF和MVC系列文章导航:EF Code First、DbContext、MVC
对于之前一直使用webForm服务器控件.手写ado.net操作数据库的同学,突然来了EF和MVC,好多新概念泉涌而出,的确犹如当头一棒不知所措.本系列文章可以帮助新手入门并熟练使用EF和MVC,有了 ...
- EF Code First 初体验
Code First 顾名思义就是先代码,再由代码生成数据库的开发方式. 废话不多说,直接来一发看看:在VS2010里新建一个空白解决方案,再依次添加两个类库项目:Model.DataAccess和一 ...
- 1.什么是Code First(EF Code First 系列)
EF4.1中开始支持Code First .这种方式在领域设计模式中非常有用.使用Code First模式,你可以专注于领域设计,根据需要,为你一个领域的对象创建类集合,而不是首先来设计数据库,然后来 ...
随机推荐
- 学习记录 java随机数的产生机制
java 随机数 一.在j2se里我们可以使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double,我们可以把他乘以一定的数,比如说乘以100,他就是个100 ...
- 在PHP5.3以上版本运行ecshop和ecmall出现的问题及解决方案
ecshop 问题一:商城首页报错 Strict Standards: Only variables should be passed by reference in D:\wamp\ecshop\i ...
- .NET平台下,关于数据持久层框架
在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...
- zedboard如何从PL端控制DDR读写(二)——AXI总线
虽然Xilinx已经将和AXI时序有关的细节都封装起来,给出了官方IP和向导生成自定义IP,用户只需要关注自己的逻辑实现,但是还是有必要简单了解一下AXI的时序,毕竟咱是做硬件设计的. AXI(Ad ...
- Oracle笔记 十四、查询XML操作、操作系统文件
--1.随机数 select dbms_random.value from dual; select mod(dbms_random.random, 10) from dual; --0-9随机数 s ...
- 在vs2005中使用AnkhSvn服务端IP改变无法连接
1.打开VS2005,选择文件-->Subversion-->Pending Changes 2.在弹出的对话框中 选择other. 荆州古城
- 基于opencv网络摄像头在ubuntu下的视频获取
基于opencv网络摄像头在ubuntu下的视频获取 1 工具 原料 平台 :UBUNTU12.04 安装库 Opencv-2.3 2 安装编译运行步骤 安装编译opencv-2.3 参 ...
- PHP用Array模拟枚举
C#中枚举Enum的写法: /// <summary> /// 公开类型 2-好友可见 1-公开 0-不公开 /// </summary> public enum OpenSt ...
- string,stringbuilder,stringbuffer
String可以储存和操作字符串,即包含多个字符的字符数据.这个String类提供了存储数值不可改变的字符串. StringBuilder是线程不安全的,运行效率高,如果一个字符串变量是在方法里面定义 ...
- ES2015 ——let命令的暂时性死区
ES6新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效. 和var不同的还有,let命令不存在变量提升,所以声明前调用变量,都会报错,这就涉及到 ...