返回顶部
首页 > 资讯 > 精选 >LINQ to SQL删除实现的示例分析
  • 149
分享到

LINQ to SQL删除实现的示例分析

2023-06-17 21:06:08 149人浏览 独家记忆
摘要

LINQ to sql删除实现的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在实现LINQ to SQL删除时可以使用Lambda Expression批量删除数

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

在实现LINQ to SQL删除时可以使用Lambda Expression批量删除数据那么在解析表达式过程中生成Where Condition会有大量的代码生成。

根据LINQ to Sql原有的设计,解析Query得到DbCommand应该是SqlProvider干的事,只是现在这个SqlProvider只从IReaderProvider出(事实上MS也没设计个IUpdateProvider或者IDeleteProvider来着),所以也只对SELECT感冒。搞的咱们只能在DataContext里自力更生了。

LINQ to SQL删除实现的实例:

不过既然已经有了可以生成SELECT的IReaderProvider,稍微把SELECT语句改造一下不就能得到DELETE了吗!基本思路:

public static int DeleteAll﹤TEntity﹥(  this Table﹤TEntity﹥ table,   Expression﹤Func﹤TEntity, bool﹥﹥ predicate)  where TEntity : class  {  IQueryable query = table.Where(predicate);  DbCommand com = dc.GetCommand(query);   //TODO:改造sql语句   return com.ExecuteNonQuery();   }  }

这里直接拿直接拿where生成的query来GetCommand,得到的sql语句大致如下:

SELECT fields... FROM tableName AS TableAlias WHERE Condition

LINQ to SQL删除的目标:

DELETE FROM tableName WHERE Condition

可见关键是得到tableName,用正则是***。不过这里还有一个缺陷就是只能用expression来做删除不能用linq query,比如我想这样:

var query = from item in context.Items  where item.Name.StartsWith("XX")  select item;  context.DeleteAll(query);

看来要把DeleteAll放到DataContext里,不过这样有风险,有可能会接受到无法转换的SELECT语句,增加判断必不可少。

LINQ to SQL删除最终完成如下:

public static class DataContextEx  {  public static int DeleteAll(  this DataContext dc, IQueryable query)  {  DbCommand com = dc.GetCommand(query);   Regex reg = new Regex("^SELECT[\\s]*(?﹤Fields﹥.*)  [\\s]*FROM[\\s]*(?﹤Table﹥.*)[\\s]*AS[\\s]*  (?﹤TableAlias﹥.*)[\\s]*WHERE[\\s]*(?﹤Condition﹥.*)",  RegexOptions.IgnoreCase);   Match match = reg.Match(com.CommandText);   if (!match.Success)  throw new ArgumentException(  "Cannot delete this type of collection");   string table = match.Groups["Table"].Value.Trim();  string tableAlias = match.Groups["TableAlias"].Value.Trim();  string condition = match.Groups["Condition"].  Value.Trim().Replace(tableAlias, table);   com.CommandText = string.FORMat(  "DELETE FROM {0} WHERE {1}", table, condition);   if (com.Connection.State != System.Data.ConnectionState.Open)  com.Connection.Open();   return com.ExecuteNonQuery();  }    public static int DeleteAll﹤TEntity﹥(  this Table﹤TEntity﹥ table, Expression﹤Func﹤TEntity, bool﹥﹥ predicate)  where TEntity : class {  IQueryable query = table.Where(predicate);   return table.Context.DeleteAll(query);  }  }

注:reg表达式取自MSDN Forum

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

--结束END--

本文标题: LINQ to SQL删除实现的示例分析

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

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

猜你喜欢
  • LINQ to SQL删除实现的示例分析
    LINQ to SQL删除实现的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在实现LINQ to SQL删除时可以使用Lambda Expression批量删除数...
    99+
    2023-06-17
  • LinQ to SQL增删改查的示例分析
    小编给大家分享一下LinQ to SQL增删改查的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!我们来看看LinQ to SQL,就是对数据库的查询,以前叫做DLinQ。经常看到LinQ那到底是什么呢?他是Lang...
    99+
    2023-06-17
  • 怎么实现LINQ to SQL删除行
    这期内容当中小编将会给大家带来有关怎么实现LINQ to SQL删除行,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。可以通过将对应的 LINQ to SQL对象从其与表相关的集合中删除来删除数据库中的行。...
    99+
    2023-06-17
  • LINQ to SQL映射列的示例分析
    小编给大家分享一下LINQ to SQL映射列的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!LINQ to SQL映射表在 LINQ to SQL 中,...
    99+
    2023-06-17
  • LINQ to SQL映射关系的示例分析
    这篇文章主要介绍LINQ to SQL映射关系的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!LINQ to SQL映射关系在 LINQ to SQL 中,数据库关联(如外键到主键关系)是通过应用 Assoc...
    99+
    2023-06-17
  • Linq to object的示例分析
    这篇文章主要介绍Linq to object的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!学习Linq to object时,经常会遇到Linq to object问题,这里将介绍XX问题的解决方法。普通存...
    99+
    2023-06-17
  • LINQ To Lucene的示例分析
    小编给大家分享一下LINQ To Lucene的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!lucene是在JAVA中比较有名的开源项目,也有.NET移...
    99+
    2023-06-17
  • LINQ To SQL的Transaction举例分析
    这篇文章主要介绍“LINQ To SQL的Transaction举例分析”,在日常操作中,相信很多人在LINQ To SQL的Transaction举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”LIN...
    99+
    2023-06-17
  • Linq To Sql性能举例分析
    这篇文章主要讲解了“Linq To Sql性能举例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linq To Sql性能举例分析”吧!Linq To Sql性能Linq To Sql性...
    99+
    2023-06-17
  • LINQ TO SQL操作据举例分析
    本篇内容介绍了“LINQ TO SQL操作据举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!LINQ TO SQL很好很强大,它几乎包...
    99+
    2023-06-17
  • LINQ TO SQL分布式事务举例分析
    本篇内容介绍了“LINQ TO SQL分布式事务举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!LINQ TO SQL,顾名思义,涉及...
    99+
    2023-06-17
  • LINQ to SQL简单的单表批量删除怎么实现
    这篇文章主要讲解了“LINQ to SQL简单的单表批量删除怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ to SQL简单的单表批量删除怎么实现”吧!如何获取SQL呢,LI...
    99+
    2023-06-17
  • LINQ to SQL动态查询举例分析
    本篇内容介绍了“LINQ to SQL动态查询举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!LINQ to SQL动态查询使用LIN...
    99+
    2023-06-17
  • C#中的LINQ to Objects实例分析
    这篇文章主要介绍了C#中的LINQ to Objects实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#中的LINQ to Objects实例分析文章都会有所收...
    99+
    2023-06-30
  • C#中的Linq to JSON操作实例分析
    今天小编给大家分享一下C#中的Linq to JSON操作实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2023-06-30
  • Linq Library的示例分析
    小编给大家分享一下Linq Library的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!PDC 05上揭露了C# 3.0及Linq Project,什么...
    99+
    2023-06-17
  • LINQ查询的示例分析
    这篇文章主要介绍LINQ查询的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在之前的C#版中,开发者应用许多不同的查询语言来访问不同的数据源。例如,要查询一个XML文件,开发者会使用XPath,要查询一个SQ...
    99+
    2023-06-17
  • LINQ to SQL是如何怎样进行删除数据的
    LINQ to SQL是如何怎样进行删除数据的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。我们在学习了LINQ to SQL之查询以及添加和更新的实现之后,现在我们来看看...
    99+
    2023-06-17
  • sql to sqlalchemy 转换的实例分析
    这篇文章将为大家详细讲解有关sql to sqlalchemy 转换的实例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。代码如下: selec...
    99+
    2024-04-02
  • Bootstrap中Table删除和批量删除的示例分析
    这篇文章主要介绍Bootstrap中Table删除和批量删除的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一条记录可以看做一条数据的数组1   ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作