主从表 级联新增

  1. Console.WriteLine("=========主从表 级联新增==========");
  2. using (var db = new Entities())
  3. {
  4. var classes = new Classes()
  5. {
  6. ClassName = "数学10501",
  7. Student = new List<Student>
  8. {
  9. new Student{StudentName="小小",Birthday=DateTime.Parse("1990-1-1")},
  10. new Student{StudentName="大大",Birthday=DateTime.Parse("1990-1-1")},
  11. }
  12. };
  13. db.Classes.Add(classes);//标记主表状态为 Added
  14. foreach (var st in classes.Student)
  15. {
  16. Console.WriteLine(db.Entry(st).State);//打印从表实体状态
  17. }
  18.  
  19. db.SaveChanges();
  20. }

追踪SQL语句:

执行结果:

说明:因为是主从表关系,所以讲主表标记为Added状态时,子表中的实体也会被标记。此处执行了3条SQL语句,分别新增班级和学生。

主从表 级联删除

先来看一下数据,两张表是外键关系。

  1. using (var db = new Entities())
  2. {
  3. var classes = db.Classes.Where(i => i.ClassName == "数学10501").FirstOrDefault();
  4. db.Classes.Remove(classes);//标记实体状态为 Deleted
  5. db.SaveChanges();
  6. }

执行结果:

说明:因为 班级表Classes 和 学生表 Student具有外键关系,所以删除班级表的数据违反了外键约定。

情况一:删除主表数据 同时标记 从表外键为NULL

  1. using (var db = new Entities())
  2. {
  3. var classes = db.Classes.Where(i => i.ClassName == "数学10501").Single();
  4.  
  5. db.Entry(classes).Collection(v => v.Student).Load();//显式加载
  6.  
  7. db.Classes.Remove(classes);//标记状态 Deleted
  8.  
  9. db.SaveChanges();
  10. }

执行结果:SQL

说明:按照EF的思路,要删除从表的外键,则同时加载主表数据和从表数据,使用Load方法。Collection方法加载导航属性是集合的类型。

情况二:删除主表数据 同时删除从表

  1. //数据库非级联状态下 删除主表数据 同时 删除从表数据
  2. using (var db = new Entities())
  3. {
  4. var classes = db.Classes.Where(i => i.ClassName == "英语10501").Single();//查询出主表数据
  5.  
  6. //此处注意 需要调用ToList方法
  7. //否则会报错 未经处理的异常: System.InvalidOperationException: 集合已修改;可能无法执行枚举操作
  8. //foreach内部是不允许修改状态的。
  9. foreach (var student in classes.Student.ToList())
  10. {
  11. db.Student.Remove(student);//手动标记从表数据为 Deleted 状态
  12. }
  13.  
  14. db.Classes.Remove(classes);//标记主表状态为 Deleted
  15.  
  16. db.SaveChanges();
  17. }

执行结果:

说明:此处数据库为非级联操作,执行时必须调用ToList方法,才能在foreach中修改状态。

【EF学习笔记10】----------主从表级联操作的更多相关文章

  1. MySQL第五个学习笔记 该数据表的操作

    MySQL在创建表,创建.frm文件保存表和列定义.索引存储在一个.MYI(MYindex)且数据存储在有.MYD(MYData)扩展名的文件里.   一.用SHOW/ DESCRIBE语句显示数据表 ...

  2. MySql cmd下的学习笔记 —— 有关建立表的操作(有关于数据类型)

    (01)建表的过程实际上是 声明字段 的过程 一. 列类型(字段): 存储同样的数据时,不同的列类型,所占据的空间和效率是不一样的,这就是建表时要考虑的意义. 二.MySQL三大列类型     数值型 ...

  3. JavaScript学习笔记(10)——JavaScript语法之操作DOM

    1.页面输出用document.write()方法,但是不可以在window.onload中用,否则整个html页面将被覆盖. 2.通过javascript获取对象后,改变对象中的html内容:doc ...

  4. Android:日常学习笔记(10)———使用LitePal操作数据库

    Android:日常学习笔记(10)———使用LitePal操作数据库 引入LitePal 什么是LitePal LitePal是一款开源的Android数据库框架,采用了对象关系映射(ORM)的模式 ...

  5. X-Cart 学习笔记(四)常见操作

    目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 五.常见 ...

  6. EF学习笔记(十二):EF高级应用场景

    学习总目录:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上篇链接:EF学习笔记(十一):实施继承 本篇原文链接:Advanced Entity Framework Scenari ...

  7. EF学习笔记(十一):实施继承

    学习总目录:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上篇链接:EF学习笔记(十) 处理并发 本篇原文链接:Implementing Inheritance 面向对象的世界里, ...

  8. EF学习笔记(十) 处理并发

    总目录:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上一篇:EF学习笔记(九):异步处理和存储过程 本篇原文链接:Handling Concurrency Concurrency ...

  9. EF学习笔记(八):更新关联数据

    学习笔记主目录链接:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上一篇链接:EF学习笔记(七):读取关联数据 本篇原文链接:Updating Related Data 本篇主要考 ...

随机推荐

  1. 打包ane之后在FB上生成ipa的阶段错误

    1. 初次打包 碰到这个错误得 就是你mac 上jre版本的问题 此时用 FB 必须是跑在jre1.6版本上的 我得是1.8 上图 版本可以自己查下 已经截图了 而且 你如果想要下载 1.6版本的 就 ...

  2. Gym 100960G (set+树状数组)

    Problem Youngling Tournament 题目大意 给一个序列a[i],每次操作可以更改一个数,每次询问 将序列排序后有多少个数a[i]>=sum[i-1]. n<=10^ ...

  3. 格式化用户输入的金额(处理RMB的时候适合)

    number_format($str,'2','.',','); function number($k){ if(strpos($k,'.')===false){ $ok = $k.'; }else{ ...

  4. ORACLE PL/SQL编程详解

    ORACLE PL/SQL编程详解 编程详解 SQL语言只是访问.操作数据库的语言,并不是一种具有流程控制的程序设计语言,而只有程序设计语言才能用于应用软件的开发.PL /SQL是一种高级数据库程序设 ...

  5. jQuery 获取父窗口的元素 父窗口 子窗口(iframe)

    $("#父窗口元素ID",window.parent.document); 对应javascript版本为window.parent.document.getElementById ...

  6. python request属性及方法说明

    if  request.REQUEST.has_key('键值'): HttpRequest对象的属性 参考: 表 H-1. HttpRequest对象的属性 属      性 描述 path 表示提 ...

  7. MapReduce简介

    MapReduce简介 参考自[http://www.cnblogs.com/swanspouse/p/5130136.html] MapReduce定义: MapReduce是一种可用于数据处理的编 ...

  8. Nginx日志常用分析命令汇总 (转)

    三.常用日志分析命令 1.总请求数 1 wc -l access.log |awk '{print $1}' 2.独立IP数 1 awk '{print $1}' access.log|sort |u ...

  9. web项目引用Java项目,连接报错error HTTP Status 500 - Servlet execution threw an exception

    错误信息 项目背景: 一个web项目引用一个java Project,项目中添加了引用,但是打开页面访问,总报500错误.提示:servlet初始化错误. 环境:Eclipse luna JDK: 1 ...

  10. knockout+bootstrap+MVC 登录页实现

    一.环境概述 1.MVC4.0项目 2.bootstrap引入: 生产环境版本引入:在web\Content 文件夹中引入bootstrap-3.2.0-dist, 源码版本CSS引入:将bootst ...