1.简单形式

说明:调用DeleteOnSubmit方法即可。

  1. OrderDetail orderDetail =
  2. db.OrderDetails.First
  3. (c => c.OrderID == && c.ProductID == );
  4. db.OrderDetails.DeleteOnSubmit(orderDetail);
  5. db.SubmitChanges();

语句描述:使用DeleteOnSubmit方法从OrderDetail 表中删除OrderDetail对象。调用SubmitChanges 将此删除保持到数据库。

2.一对多关系

说明:Order与OrderDetail是一对多关系,首先DeleteOnSubmit其OrderDetail(多端),其次DeleteOnSubmit其Order(一端)。因为一端是主键。

  1. var orderDetails =
  2. from o in db.OrderDetails
  3. where o.Order.CustomerID == "WARTH" &&
  4. o.Order.EmployeeID ==
  5. select o;
  6. var order =
  7. (from o in db.Orders
  8. where o.CustomerID == "WARTH" && o.EmployeeID ==
  9. select o).First();
  10. foreach (OrderDetail od in orderDetails)
  11. {
  12. db.OrderDetails.DeleteOnSubmit(od);
  13. }
  14. db.Orders.DeleteOnSubmit(order);
  15. db.SubmitChanges();

语句描述语句描述:使用DeleteOnSubmit方法从Order 和Order Details表中删除Order和Order Detail对象。首先从Order Details删除,然后从Orders删除。调用SubmitChanges将此删除保持到数据库。

3.推理删除(Inferred Delete)

说明:Order与OrderDetail是一对多关系,在上面的例子,我们全部删除CustomerID为WARTH和EmployeeID为3 的数据,那么我们不须全部删除呢?例如Order的OrderID为10248的OrderDetail有很多,但是我们只要删除ProductID为11的OrderDetail。这时就用Remove方法。

  1. Order order = db.Orders.First(x => x.OrderID == );
  2. OrderDetail od =
  3. order.OrderDetails.First(d => d.ProductID == );
  4. order.OrderDetails.Remove(od);
  5. db.SubmitChanges();

语句描述语句描述:这个例子说明在实体对象的引用实体将该对象从其EntitySet 中移除时,推理删除如何导致在该对象上发生实际的删除操作。仅当实体的关联映射将DeleteOnNull设置为true且CanBeNull 为false 时,才会发生推理删除行为。

使用Attach更新(Update with Attach)

说明:在对于在不同的DataContext之间,使用Attach方法来更新数据。例如在一个名为tempdb的NorthwindDataContext中,查询出Customer和Order,在另一个NorthwindDataContext中,Customer的地址更新为123 First Ave,Order的CustomerID 更新为CHOPS。

  1. //通常,通过从其他层反序列化 XML 来获取要附加的实体
  2. //不支持将实体从一个DataContext附加到另一个DataContext
  3. //因此若要复制反序列化实体的操作,将在此处重新创建这些实体
  4. Customer c1;
  5. List<Order> deserializedOrders = new List<Order>();
  6. Customer deserializedC1;
  7. using (NorthwindDataContext tempdb = new NorthwindDataContext())
  8. {
  9. c1 = tempdb.Customers.Single(c => c.CustomerID == "ALFKI");
  10. deserializedC1 = new Customer
  11. {
  12. Address = c1.Address,
  13. City = c1.City,
  14. CompanyName = c1.CompanyName,
  15. ContactName = c1.ContactName,
  16. ContactTitle = c1.ContactTitle,
  17. Country = c1.Country,
  18. CustomerID = c1.CustomerID,
  19. Fax = c1.Fax,
  20. Phone = c1.Phone,
  21. PostalCode = c1.PostalCode,
  22. Region = c1.Region
  23. };
  24. Customer tempcust =
  25. tempdb.Customers.Single(c => c.CustomerID == "ANTON");
  26. foreach (Order o in tempcust.Orders)
  27. {
  28. deserializedOrders.Add(new Order
  29. {
  30. CustomerID = o.CustomerID,
  31. EmployeeID = o.EmployeeID,
  32. Freight = o.Freight,
  33. OrderDate = o.OrderDate,
  34. OrderID = o.OrderID,
  35. RequiredDate = o.RequiredDate,
  36. ShipAddress = o.ShipAddress,
  37. ShipCity = o.ShipCity,
  38. ShipName = o.ShipName,
  39. ShipCountry = o.ShipCountry,
  40. ShippedDate = o.ShippedDate,
  41. ShipPostalCode = o.ShipPostalCode,
  42. ShipRegion = o.ShipRegion,
  43. ShipVia = o.ShipVia
  44. });
  45. }
  46. }
  47. using (NorthwindDataContext db2 = new NorthwindDataContext())
  48. {
  49. //将第一个实体附加到当前数据上下文,以跟踪更改
  50. //对Customer更新,不能写错
  51. db2.Customers.Attach(deserializedC1);
  52. //更改所跟踪的实体
  53. deserializedC1.Address = "123 First Ave";
  54. //附加订单列表中的所有实体
  55. db2.Orders.AttachAll(deserializedOrders);
  56. //将订单更新为属于其他客户
  57. foreach (Order o in deserializedOrders)
  58. {
  59. o.CustomerID = "CHOPS";
  60. }
  61. //在当前数据上下文中提交更改
  62. db2.SubmitChanges();
  63. }

语句描述:从另一个层中获取实体,使用Attach和AttachAll将反序列化后的实体附加到数据上下文,然后更新实体。更改被提交到数据库。

使用Attach更新和删除(Update and Delete with Attach)

说明:在不同的DataContext中,实现插入、更新、删除。看下面的一个例子:

  1. //通常,通过从其他层反序列化XML获取要附加的实体
  2. //此示例使用 LoadWith 在一个查询中预先加载客户和订单,
  3. //并禁用延迟加载
  4. Customer cust = null;
  5. using (NorthwindDataContext tempdb = new NorthwindDataContext())
  6. {
  7. DataLoadOptions shape = new DataLoadOptions();
  8. shape.LoadWith<Customer>(c => c.Orders);
  9. //加载第一个客户实体及其订单
  10. tempdb.LoadOptions = shape;
  11. tempdb.DeferredLoadingEnabled = false;
  12. cust = tempdb.Customers.First(x => x.CustomerID == "ALFKI");
  13. }
  14. Order orderA = cust.Orders.First();
  15. Order orderB = cust.Orders.First(x => x.OrderID > orderA.OrderID);
  16. using (NorthwindDataContext db2 = new NorthwindDataContext())
  17. {
  18. //将第一个实体附加到当前数据上下文,以跟踪更改
  19. db2.Customers.Attach(cust);
  20. //附加相关订单以进行跟踪; 否则将在提交时插入它们
  21. db2.Orders.AttachAll(cust.Orders.ToList());
  22. //更新客户的Phone.
  23. cust.Phone = "2345 5436";
  24. //更新第一个订单OrderA的ShipCity.
  25. orderA.ShipCity = "Redmond";
  26. //移除第二个订单OrderB.
  27. cust.Orders.Remove(orderB);
  28. //添加一个新的订单Order到客户Customer中.
  29. Order orderC = new Order() { ShipCity = "New York" };
  30. cust.Orders.Add(orderC);
  31. //提交执行
  32. db2.SubmitChanges();
  33. }

语句描述:从一个上下文提取实体,并使用 Attach 和 AttachAll 附加来自其他上下文的实体,然后更新这两个实体,删除一个实体,添加另一个实体。更改被提交到数据库。

LINQ to SQL语句(12)之Delete和使用Attach的更多相关文章

  1. 年终巨献 史上最全 ——LINQ to SQL语句

    LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...

  2. LINQ to SQL语句非常详细(原文来自于网络)

    LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子 ...

  3. LINQ to SQL语句

    http://kb.cnblogs.com/page/42477/2/ 本系列文章导航 LINQ to SQL语句(1)之Where LINQ to SQL语句(2)之Select/Distinct ...

  4. LINQ to SQL语句对应SQL的实现

    LINQ to SQL语句(1)之Where LINQ to SQL语句(2)之Select/Distinct LINQ to SQL语句(3)之Count/Sum/Min/Max/Avg LINQ ...

  5. LINQ to SQL语句大全

    LINQ to SQL语句大全     LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判 ...

  6. 【转】LINQ to SQL语句(1)之Where

    Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句. Where操作包括3种形式,分别为简单形 ...

  7. 史上最全 ——LINQ to SQL语句

    LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...

  8. LINQ体验(9)——LINQ to SQL语句之Insert/Update/Delete操作

    我们继续讲解LINQ to SQL语句,这篇我们来讨论Insert/Update/Delete操作.这个在我们的程序中最为常用了.我们直接看例子. Insert/Update/Delete操作 插入( ...

  9. LINQ to SQL语句(7)之Exists/In/Any/All/Contains

    适用场景:用于判断集合中元素,进一步缩小范围. Any 说明:用于判断集合中是否有元素满足某一条件:不延迟.(若条件为空,则集合只要不为空就返回True,否则为False).有2种形式,分别为简单形式 ...

随机推荐

  1. (翻译)《Hands-on Node.js》—— Why?

    事出有因 为何选择event loop? Event Loop是一种推进无阻塞I/O(网络.文件或跨进程通讯)的软件模式.传统的阻塞编程也是用一样的方式,通过function来调用I/O.但进程会在该 ...

  2. EQueue - 一个纯C#写的分布式消息队列介绍2

    一年前,当我第一次开发完EQueue后,写过一篇文章介绍了其整体架构,做这个框架的背景,以及架构中的所有基本概念.通过那篇文章,大家可以对EQueue有一个基本的了解.经过了1年多的完善,EQueue ...

  3. 一个App完成入门篇(七)- 完成发现页面

    第七章是入门篇的倒数第二篇文章了,明天整个APP将进入收官. 本节教程主要要教会大家使用二维码扫描和用do_WebView组件加在html页面. 导入项目 do_WebView组件 扫描功能 自定义事 ...

  4. [.net 面向对象程序设计进阶] (17) 多线程(Multithreading)(二) 利用多线程提高程序性能(中)

    [.net 面向对象程序设计进阶] (17) 多线程(Multithreading)(二) 利用多线程提高程序性能(中) 本节要点: 上节介绍了多线程的基本使用方法和基本应用示例,本节深入介绍.NET ...

  5. C#图片色彩的纠正-上

    WPF(C#)图片色彩的纠正-上 WPF(C#)图片色彩的纠正-下 前言 对图片进行色彩的纠正,其实与WPF是没有什么关系的,为什么标题又是“WPF(C#)图片色彩的纠正”呢,因为这些图片色彩的纠正功 ...

  6. DOM访问元素样式和操作元素样式

    在HTML中定义样式的方式有三种:通过<link/>元素包含外部样式表文件(外部样式表).使用<style/>元素定义嵌入式样式(嵌入式样式表).使用style特性定义针对特定 ...

  7. selenium结合最新版的sikuli使用

    sikuli安装,下载sikulixsetup-1.1.0.jar,地址:https://launchpad.net/sikuli/sikulix/1.1.0 在装有Java环境的机器上直接双击jar ...

  8. SSISDB5:Parameter

    Parameter 是Package 提供给外界的接口,通过传递不同的Parameter value,能够动态控制 Package 执行不同的Task或container,产生不同的结果. 一,Par ...

  9. 【Win10应用开发】自定义磁贴通知的排版

    前面老周用了两篇烂文,向大家介绍了Adaptive磁贴的模板使用.那些XML模板已经很强大了,不过,如果你觉得那些排版还不足以满足需求,不妨试试自己来定义磁贴的内容. 其实,Runtime App支持 ...

  10. 深入理解DOM事件机制系列第三篇——事件对象

    × 目录 [1]获取 [2]事件类型 [3]事件目标[4]事件代理[5]事件冒泡[6]事件流[7]默认行为 前面的话 在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含着所有与事 ...