LinqToSql ,EF:外键实体的CRD

2011-03-06 21:56:26|  分类: linq |  标签:编程  |字号 订阅

 
 
      接触LinqTosql是很久的事情了,之前一直在拼接字符串,所以一开始就很喜欢这种ORM的方式,强类型用的爽啊,最近开始

改为学习ADO.NET 实体框架了:),概念上的东西网上都很多,当我想实现一个简单的外键表操作时,却没有一个较好的例子,

经过一段摸索后,将最简单的情形给贴出来。

本文用这2种方式通过一个简单的外键关系来演示Insert,Update,Delete操作

DB中建立2张表,这里只考虑1对多的关系:

LinqToSql的方式:

生成的TestDB.dbml:

Insert:

        using(TestDBDataContext db=new TestDBDataContext())  
        {  
            Depatment depatment = new Depatment() {DeptName = "开发部"};  
            Employee employee = new Employee()  
                                    {  
                                        EmpName = "Ringgo.Yao",  
                                        Depatment = depatment  
                                    };  
            db.Depatment.InsertOnSubmit(depatment);  
            db.SubmitChanges();  
        }

当提交Department时,会自动提交Employee

Update:

        using (TestDBDataContext db = new TestDBDataContext())  
        {  
            Depatment depatment = db.Depatment.Where(i => i.DeptId ==2).First();  
            depatment.DeptName = "研发部";  
            Employee employee = new Employee()  
            {  
                EmpName = "Ringgo.Yao",  
                Depatment = depatment  
            };              
            db.SubmitChanges();  
        }

这里修改Department记录的同时添加了一条Employee记录

Delete:

       using (TestDBDataContext db = new TestDBDataContext())  
        {  
          Depatment depatment=db.Depatment.Where(i => i.DeptId == 3).First();  
          var employees=db.Employee.Where(i => i.DeptId == 3).ToList();    
          db.Employee.DeleteAllOnSubmit(employees);  
          db.Depatment.DeleteOnSubmit(depatment);  
          db.SubmitChanges();  
        }

删除的时候要先删除Employee,再删除Department

ADO.NET Entity Framework的方式:

生成的TestDB.edmx:

因为代码看起来似乎区别不大,所以就不进行说明了

Insert:

        using(TestDBEntities db=new TestDBEntities())  
        {  
            Depatment depatment = new Depatment() {DeptName = "开发部"};  
            Employee employee = new Employee() {EmpName = "Ringgo.Yao"};  
            depatment.Employee.Add(employee);  
            db.Depatment.AddObject(depatment);  
            db.SaveChanges();  
        }

Update:

        using (TestDBEntities db = new TestDBEntities())  
        {  
            var dept = db.Depatment.Where(i => i.DeptId == 1).First();  
            dept.DeptName = "研发部";  
            Employee employee = new Employee() {EmpName = "White"};  
            dept.Employee.Add(employee);  
            db.SaveChanges();  
        }
  Delete:
       using (TestDBEntities db = new TestDBEntities())  
        {  
            var dept = db.Depatment.Where(i => i.DeptId == 1).First();  
            foreach (var emp in dept.Employee.ToList())  
            {                  
                dept.Employee.Remove(emp);  
                db.Employee.DeleteObject(emp);  
            }  
            db.Depatment.DeleteObject(dept);  
            db.SaveChanges();  
        }

LinqToSql增加、修改、删除---(转载)的更多相关文章

  1. Oracle 增加修改删除字段

    Oracle 增加修改删除字段 添加字段的语法:alter table tablename add (column datatype [default value][null/not null],…. ...

  2. Oracle 增加修改删除字段与添加注释

    添加字段的语法:alter table tablename add (column datatype [default value][null/not null],….); 修改字段的语法:alter ...

  3. hibernate 批量增加 修改 删除

    4.2  Hibernate的批量处理 Hibernate完全以面向对象的方式来操作数据库,当程序里以面向对象的方式操作持久化对象时,将被自动转换为对数据库的操作.例如调用Session的delete ...

  4. Oracle-表的字段增加修改删除操作

    表结构修改 ALTER TABLE SCOTT.TEST RENAME TO TEST1--修改表名 ALTER TABLE SCOTT.TEST RENAME COLUMN NAME TO NAME ...

  5. js jquery select 操作 获取值,选中选项,增加,修改,删除

    select示例: <select id="sel"> <option value="1">one</option> < ...

  6. Oracle 增加 修改 删除 列

    语法结构如下: alter table tablename add (column datatype [default value][null/not null],….); alter table t ...

  7. openlayers中实现点的拖拽(modify),在layer中增加修改删除point。

    最近忙着整地图,都忘记了总结来沉淀自己,自我检讨一下. 总结一下最近使用openlayer时学习的内容,先说下我的业务逻辑吧,在室内地图中 1,点击新增在地图上新增一个可以拖拽的点,拖拽完成后确定位置 ...

  8. ado.net c#基本的增加,修改,删除,查询

    自己初次学习用的,各种不规范,注释没写 class AdoDemo { static string strConn = @"Data Source=server1;Initial Catal ...

  9. Mysql中用SQL增加、删除、修改(包括字段长度/注释/字段名)总结

    转: Mysql中用SQL增加.删除.修改(包括字段长度/注释/字段名)总结 2018年09月05日 10:14:37 桥Dopey 阅读数:1830   版权声明:本文为博主原创文章,未经博主允许不 ...

  10. iOS --SQL的增加、删除、查找、修改

    iOS对于数据库的操作:增加.删除.查找.修改 首先需要创建一个数据库:本程序的数据库是在火狐浏览器里的插件里写的微量型数据库 火狐找查找SQLite Manager的步骤: 第一步:在工具栏找到附加 ...

随机推荐

  1. 研究 UIActivityViewController

    研究 UIActivityViewController 发布于:2014-04-25 09:51阅读数:5903 特定的编程语言,如 Lisp.lo 和 Mathematica 都是同像性的(homo ...

  2. 在UC浏览器上很炫的一个效果

    效果简述: 这个效果将会强行去除UC浏览器的网址输入框和底部的菜单栏,这样网页将会占据整个手机界面.感觉看起来很像是一个APP. 浏览器界面右下角将会出现一个向上的标志,用来唤出简单的菜单栏. (界面 ...

  3. unix c 08

    信号 - signal()改变信号的处理方式.默认情况下,信号在Unix中都有自己的处理方式,如果想改变信号的处理方式,signal/sigaction 可以实现. 信号可以在关键代码处进行屏蔽,因为 ...

  4. STL适配器的初步理解

    c++中的适配器有三种:容器适配器,迭代器适配器,函数适配器.下面一一介绍: 1.容器适配器:因为这些容器都是基于其他标准容器实现的所以叫做容器的适配器,具体的有stack,queue,priorit ...

  5. AsyncTask实现下载图片

    实现效果: /*采用异步任务  AsyncTask<String,Integer, byte[]>  * 参数一代表 执行异步任务时传递的参数的类型  * 参数二 如果不采用进度,则填Vo ...

  6. BackgroundWorker用法

    BackgroundWorker主要用来提供后台运算服务(防止用户前台无响应等待),并提供服务进度的类: 代码如下: BackgroundWorker bgw = new BackgroundWork ...

  7. Direct3D 光照和材质

      今天我们来学习下Direct3D里面的光源和材质. 四大光照类型: 环境光 Ambient Light 一个物体没有被光照直接照射,通过每一些物体反射的光线到达这个物体,它也有可能被看到.这种称为 ...

  8. TCP和UDP的区别(转)

    TCP协议与UDP协议的区别    首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! ...

  9. [转载]Vertica “ERROR: Too many ROS containers exist”

    最近在用Vertica的时候碰到一个问题,Vertica在运行了一段时间后总是出现类似下面的错误 1: java.sql.SQLException: [Vertica][VJDBC](5065) 2: ...

  10. PC--CSS技巧

    1.图片不存在的时候,显示一个默认图片 <img src=”01.jpg” onerror=”this.src=’02.jpg'” /> 2.CSS强制图片自适应大小 img {width ...