当前位置:  开发笔记 > 编程语言 > 正文

使用Linq to SQL确定行是否存在的最快方法是什么?

如何解决《使用LinqtoSQL确定行是否存在的最快方法是什么?》经验,为你挑选了2个好方法。

我对行的内容不感兴趣,我只想知道是否存在行.该Name列是主键,因此将有0或1个匹配的行.目前,我正在使用:

if ((from u in dc.Users where u.Name == name select u).Count() > 0)
    // row exists
else
    // row doesn't exist

虽然上述工作,但通过选择行的所有内容(如果存在),它会做很多不必要的工作.以下是否创建更快的查询:

if (dc.Users.Where(u => u.Name == name).Any())

...或者是否有更快的查询?



1> Marc Gravell..:

这种Count()方法可以做额外的工作,如(在TSQL中)EXISTSTOP 1通常更快; db可以优化"至少有一行".就个人而言,我会使用any/predicate重载:

if (dc.Users.Any(u => u.Name == name)) {...}

当然,你可以通过观察TSQL来比较每个人做的事情:

dc.Log = Console.Out;


@David - 的确如此.我一直要求MS数据团队将其添加到EF ;-p
特别是因为我从未意识到Linq to Sql的SQL日志记录功能.我一直在运行SQL Profiler.

2> 小智..:

当然

if (dc.Users.Where(u => u.Name == name).Any())

这是最好的,如果要检查多个条件,那么写起来非常简单

假设您要检查公司的用户

if (dc.Users.Where(u => u.ID== Id && u.Company==company).Any())

推荐阅读
Life一切安好
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有