InfoQ

新闻

扩展LINQ to SQL以支持批量删除

作者 朱永光 发布于 2008年4月1日 下午12时9分

社区
.NET
主题
数据访问,
.NET框架
标签
C#,
LINQ,
.NET Framework Programming

最近,博客园的老赵在其博客上发表了一篇博客文章,其中谈到了一种扩展LINQ to SQL以支持批量删除数据的方法,可以让我们方便地利用Lambda表达式来进行批量删除的操作。

LINQ to SQL要根据条件批量删除数据,通常的做法都是编写SQL语句,并通过DataContext的ExecuteCommand方法来执行删除操作。这样的方法很直接,但是不够自然,如老赵所说:

我始终认为,在程序里出现直接的SQL语句是一件很丑陋的事情。在我看来,数据库操作应该被封装起来,而对于应用层的开发人员来说,眼中应该只有对象——退一步的话也可向数据库发送指令(就是使用存储过程)。

在此之前,老赵也写过类似扩展LINQ to SQL的文章,其利用了LINQ to SQL中Translate方法来修改动态生成的SQL语句。不过,这次对于批量删除的扩展,老赵使用C# 3.0的新特性——扩展方法,来针对System.Data.Linq.Table实现了一个名为Delete的扩展方法,在引用了这个扩展包后,就可以通过如下类似的代码来进行批量删除数据的操作:

ItemDataContext db = new ItemDataContext();
db.Items.Delete(item => item.CreateTime < DateTime.UtcNow.AddMonths(-1));

扩展还支持更复杂的删除条件

ItemDataContext db = new ItemDataContext();
db.Items.Delete(item =>
    item.CreateTime < DateTime.UtcNow.AddMonths(-1) ||
    item.ViewCount < item.CommentCount && item.UserName != "jeffz");

老赵的这种方法,是对Lambda的表达式树进行解析后生成DELETE SQL的Where条件子句。他使用了三个步骤来完成这个解析工作:

  • 使用PartialEvaluator将表达式中的常量直接计算出来(例如“3 * 3”表达式将被替换为“9”),同时也会将一些存储在变量中的值使用常量进行替换。
  • 使用ConditionBuilder将表达式中的常量收集起来,并生成带参数的Condition表达式(例如“[CreateTime] < {0} AND [UserName] <> {1}”)。
  • 使用DataContext.ExecuteCommand方法执行完整的SQL语句。

而另外一个博主,Black Jack,在老赵文章的提示下,使用了一种“投机取巧”的方式来生成批量删除数据的SQL语句。他的思路是,从Query中获取自动生成的SELECT SQL语句,并将其改造为DELETE SQL语句。改造的时候使用正则表达式来进行查找和替换。关于这种方式的详细做法,可以浏览Linq to Sql: 批量删除之投机取巧版这篇文章。

对于这种扩展LINQ to SQL以支持批量删除的做法,有些人认为还是直接编写SQL更方便。然而,越来越多的人都在积极尝试扩展LINQ to SQL,这样可以让我们既获得LINQ to SQL带来的好处,又能实现一些更复杂的功能。

相关赞助商

InfoQ中文站.NET社区,关注.NET和微软的其他企业开发解决方案,通过新闻、文章、视频访谈和演讲以及迷你书等为中国.NET社区提供一流资讯。

没有回复

回复

独家内容

构建的可伸缩性和达到的性能:一个虚拟座谈会

这个由业界主要专家们参加的座谈会探究了在使应用程序具备尽可能好的伸缩性及性能的过程中所面临的挑战和思考过程。

OpenSocial的分析与实现

本视频主要对OpenSocial进行了分析,并对实现的方式进行了介绍。其中包括:OpenSocial的开发经验、Container Provider的技术准备、平台的构成要素、具体的规范、以及对未来的展望。

缓存系统MemCached的Java客户端优化历程

Memcached在大型网站被应用得越来越广泛,但是Java客户端并不多,本文作者基于现有的开源客户端进行了封装优化,并翔实记录了这一过程。

超越SOA:动态业务应用的新企业应用框架(2)

在他们文章的第二部分,作者探讨了动态业务应用的架构并介绍了资源容器的概念。他们示范了如何在JEE之上构建这个架构,以及它如何影响实现生产力。

使用ClickOnce细分发布版本

ClickOnce让WinForms应用程序的部署轻而易举。David Cooksey演示了如何在ASP.NET中编写一个HttpHandler来实现对ClickOnce部署的版本细分。

敏捷教练,从A到Z

敏捷带来了新的领导者角色,“敏捷教练”。它是不是跟“部门经理”或“技术领导”一样,只是换汤不换药呢?教练Pat Kua在这篇启蒙文章中对敏捷教练一职做了概述。

利用Ruby简化你的Java测试(进阶篇)

本文是Productive Java with Ruby系列文章的第二篇,通过上一篇的介绍,我想大家对如何利用Ruby进行单元测试有了一个基本的了解,从这里开始,我将和大家一起讨论一些利用Ruby进行单元测试时的高级话题。

书评:《应用SOA》

《应用SOA》是由四位一流SOA专家合著关于SOA的新书,其主旨是帮助你成功地实施SOA。尤其是,这本书将帮助你把你的SOA项目与企业架构、IT治理、核心数据和BPM项目结合起来。