当前位置:主页   - 电脑 - 网站开发 - ASP.Net
Linq to SQL之删除
来源:网络   作者:   更新时间:2012-08-03
收藏此页】    【字号    】    【打印】    【关闭

  首先以Customers表的一行数据为例,进行数据删除:

 NorthwindDataContext ctx = new NorthwindDataContext();

 Customer test1 = ctx.Customers.Single(c => c.CustomerID == "TEST1");

 ctx.Customers.Remove(test1);

 ctx.SubmitChanges();

 通过查看数据库中的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中查询该数据,肯定是查询不到的。

   下面介绍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();

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

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明