大牛们快来啊,linq to sql

zhanglong_longlong 2013-04-16 09:43:20
/// <summary>
/// 按条件删除多条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
/// <param name="fun"></param>
public void DeleteToMany<T>(DataContext dc, IEnumerable<T> tentitys, Func<T, bool> fun) where T : class
{
var table = dc.GetTable<T>();
var result = table.Where<T>(fun).AsEnumerable<T>();
table.DeleteAllOnSubmit<T>(result);
dc.SubmitChanges();
}

/// <summary>
/// LINQ更新方法
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="fun"></param>
/// <param name="tentity"></param>
/// <param name="action"></param>
public void Update<T>(DataContext dc, Func<T, bool> fun, T tentity, Action<T> action) where T : class
{
var table = dc.GetTable<T>().Single<T>(fun);
//var table = dc.GetTable<T>().Where<T>(fun).Single<T>();
action(table);
dc.SubmitChanges();
}

红色的我应该怎么传值调用啊,帮忙示范下,在线等!!!
...全文
264 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhanglong_longlong 2013-04-16
  • 打赏
  • 举报
回复
542800202加下,谢谢
zhanglong_longlong 2013-04-16
  • 打赏
  • 举报
回复
谢谢,加我下扣扣吧,我是高歌的朋友
gxingmin 2013-04-16
  • 打赏
  • 举报
回复
是的,你试试看
zhanglong_longlong 2013-04-16
  • 打赏
  • 举报
回复
IEnumerable<T> tentitys,//此参数直接传你的实体 是不是要这样才行 List<Photo> aa = new List<Photo>(); DeleteToMany<Photo>(new DataClasses1DataContext(), aa, x => x.Name == "aa");
gxingmin 2013-04-16
  • 打赏
  • 举报
回复
IEnumerable<T> tentitys,//此参数直接传你的实体 Func<T, bool> fun//此参数可以传类似 t=>t.字段=="abc" Action<T> action需要你定义委托...
zhanglong_longlong 2013-04-16
  • 打赏
  • 举报
回复
支持下,没人知道吗,在线等
张发_2012 2013-04-16
  • 打赏
  • 举报
回复
请不要拉 高歌 下水
走进Linq--Linq横空出世篇 某日编程大师云游到某处,见一刚毕业不久学过两天C#和两天SQL的coder在那里发牢骚,为啥我要写这么多for,这么多if才能查询出我需要的数据,为啥我不能像SQL那样,发送一条命令告诉数据库我需要啥样的数据,它就给我返回来。 编程大师如是说:傻小子,像SQL那叫第四代编程语言,常存在于象牙塔和研究所里面的学究语言,还有个高雅的名字:函数编程。它只需要你告诉它要什么,而不需要告诉它怎么做。而你使用的C#语言属于命令式编程,你必须像发送命令一样一步步的告诉你的机器怎么做。 发牢骚的coder回了一句:不懂,我只是想不通,数据库能做这样的处理,为啥C#这么牛的语言不能呢。编程大师心里想着:这是不可能的事情,因为C#它是强类型语言,)*&)(&)*)()*&%&%&^(后面省去200字)。 天色还未晚,编程大师就急匆匆的回家了,他心里一直记着那位发牢骚的coder的话:为什么不能,为什么不能。 晚上,编程大师做了一个梦,一个奇怪的梦,他的师傅“白眉”只说了三个字母:DSL。 编程大师想着,DSL,领域专用语言,师傅要对我说什么呢,难道和今天我遇见的事有关? 上面这段文字是一段调侃,调节一下气氛,呵呵。 我觉得Linq就是一种DSL,在C#等常规语言上抽象起来的,面向数据处理领域的特定“语言”,当然,它的根基还是这些常规语言。 select,from,where,group等关键字本来只是在SQL里出现,现在把它们引入到C#这些常规编程语言中。 那C#等是如何做到的呢?是在CLR底层支持的么?不是。既然“编译器”可以将C#编译成MSIL,那为什么编译不能干更多一点事情?将这些为了领域编程而出现关键字编译成原始语法。

62,050

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧