iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >LINQ to SQL是如何怎样进行删除数据的
  • 390
分享到

LINQ to SQL是如何怎样进行删除数据的

2023-06-17 22:06:45 390人浏览 安东尼
摘要

LINQ to sql是如何怎样进行删除数据的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。我们在学习了LINQ to SQL之查询以及添加和更新的实现之后,现在我们来看看

LINQ to sql是如何怎样进行删除数据的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

我们在学习了LINQ to SQL之查询以及添加和更新的实现之后,现在我们来看看,LINQ to SQL是如何怎样进行删除数据的,具体的实现过程和步骤是什么呢?让我们来看看。

LINQ to SQL删除数据以Northwind为例子:

1、首先以Customers表的一行数据为例,来实现LINQ to SQL删除:

NorthwindDataContext ctx = new NorthwindDataContext();   Customer test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");   ctx.Customers.Remove(test1);   ctx.SubmitChanges();

2、通过查看数据库中的Customers表,可以发现该条数据已经被删除了。

NorthwindDataContext ctx = new NorthwindDataContext();  Customer test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");  ctx.Customers.Remove(test1);  ctx.SubmitChanges();   test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");  Console.WriteLine(test1.CustomerID);

先删除CustomerID为"TEST1"的一行数据,然后再在数据库中查询该条数据,理论上来说数据库中该数据已经不存在了,查询出来应该没有结果。可是屏幕输出为"TEST1",这是已经被删除的Customer的CustomerID。是不是会让人觉得奇怪,数据库中数据已经不存在了,但是查询还是可以得到正确的结果。其实原因也很简单,虽然在数据库中该数据已经被删除,但是在DataContext中的Identity Cache还保存着对该对象的引用(什么是Identity Cache,前文已经解释过了),查询出来的结果是在DataContext中Cache着的对象而不是存在于数据库中的。可以知道如果在另一个DataContext中查询该数据,肯定是查询不到的。

3、LINQ to SQL删除中的级联删除,以Customers和Orders为例:

NorthwindDataContext ctx = new NorthwindDataContext();  Customer test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");   Order order1 = test1.Orders.Single(o => o.ShipCity == "Shanghai");  test1.Orders.Remove(order1);   ctx.SubmitChanges();

在该示例中,欲删除CustomerID为"TEST1"的Customer的订单中ShipCity为上海的订单。执行这段代码,通过SQL Profile可以发现,并没有运行delete from Orders...的SQL语句而是update,只是把Orders表中那条记录的CustomerID设置为NULL,删除的是该记录与Customer的关系而并没有真正删除这条记录。要想真正删除该记录必须通过DataContext来操作:

ctx.Orders.Remove(order1);   ctx.SubmitChanges();

这是在删除过程中值得注意的一个问题。

要删除Customer以及相关的Order应该这样来操作(也可以在数据库中设置级联删除):

NorthwindDataContext ctx = new NorthwindDataContext();  Customer test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");   foreach (Order o in test1.Orders)  {  test1.Orders.Remove(o);  ctx.Orders.Remove(o);  }  ctx.Customers.Remove(test1);   ctx.SubmitChanges();

在数据删除时也会遇到像数据更新一样的冲突问题,解决方法基本相同这里就不多说了。

关于LINQ to SQL是如何怎样进行删除数据的问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: LINQ to SQL是如何怎样进行删除数据的

本文链接: https://www.lsjlt.com/news/293612.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作