微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – Linq to Sql Count包含连接

我有一个 Linq to sql如下:
var members=db.Members.Include(x=> x.Contact).Count();

现在由于一些不良数据,我的成员中的所有联系人都没有相应的联系人记录.因此,在计数期间,如何将内部联接后的计数包含在Contact表中.

问题是,当我获得成员列表时,成员列表有100个记录,而Count有150个记录(50个记录是坏数据).

var membersQ=db.Members.Include(x=> x.Contact).Select(i=> new Memberviewmodel(){
 Name = i.Contact.Name,ContactId= i.Contact.Id,CreatedDate= i.CreatedDate
}).AsQueryable();
var members=memberQ.ToList();// =100,paging is done...
// the memebers list uses paging but the count doesn't
var total=membersQ.Count(); // =150

我在计数期间检查了结果查询,显然它没有与Contact表进行JOIN而Count()

更新
数据库结构

Member Table
Id   ContactId,CompanyId,CreatedDate ...

Contact Table
Id   Name ...

Member表中ContactId的外键不是在数据库级别设置,而是仅在Model上设置.

[ForeignKey("ContactId")]
Public Contact Contact { get; set; }

糟糕的数据是这样的

我之前有1,2,3,4,5,6,7,8,9,10作为联系人记录,所有这些联系人也在会员表中.

现在我从Contact表中删除记录,比如说6-10.但碰巧没有从会员表中删除.

所以这导致计数问题.是的,从成员中删除不良数据可以解决问题,但问题是如何在使用Count()时使用join.

注意:我使用数据库初始化器null

更新2
我使用LinqPad并尝试了认的Linq To sql和EntityFramework(DbContext)连接,我发现的是令人困惑的.

对于查询

(from a in Members
join b in Contacts on a.ContactId equals b.ContactId
select a).Count()

使用认Linq To sql

SELECT COUNT(*) AS [value]
FROM [Member] AS [t0]
INNER JOIN [Contact] AS [t1] ON [t0].[ContactID] = [t1].[ContactID]

使用Entityframework DbContext

SELECT 
    [GroupBy1].[A1] AS [C1]
    FROM ( SELECT 
        COUNT(1) AS [A1]
        FROM [dbo].[Member] AS [Extent1]
    )  AS [GroupBy1]

在我的代码中,我使用DbContext方法.所以……不知道该怎么做
.
顺便说一句:抱歉有一个带linq-to-sql标签,它实际上是entityframework

解决方法

那这个呢:
var x = from m in Members 
        join c in Contacts on  m.ContactId equals c.ID
        select new 
        {
            Name = c.Name,ContactId= c.ID,CreatedDate= c.CreatedDate
        };

Console.Write(x.Count());

编辑

当我使用LinqPad与此查询并查看生成sql时,我得到:

SELECT COUNT(*) AS [value]
FROM [Members] AS [t0]
INNER JOIN [Contact] AS [t1] ON [t0].[ContactId] = ([t1].[ID])

编辑2

你也可以试试这个:

var x = from c in Contacts
        from m in Members where m.ContactId == c.ID
        select new 
        {
            Name = c.Name,CreatedDate= c.CreatedDate
        };

Console.Write(x.Count());

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


原文地址:http://msdn.microsoft.com/en-us/magazine/cc163791.aspx 原文发布日期: 9/19/2005 原文已经被 Microsoft 删除了,收集过程中发现很多文章图都不全,那是因为原文的图都不全,所以特收集完整全文。 目录 前言 CLR启动程序
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采纳和使用,它的确提供了很多的优势也解决了很多的问题,但是我们也知道也并不是银弹,提供优势的同时它也给我们的开发人员和团队也带来了很多的挑战。 为了迎接或者采用这些新技术,开发团队需要更加注重一些流程或工具的使用,这样才能更好的适应这些新技术所
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下PLINQ中的分区。上一篇介绍了并行编程,这边详细介绍一下并行编程中的分区和自定义分区。 先做个假设,假设我们有一个200Mb的文本文件需要读取,怎么样才能做到最优的速度呢?对,很显然就是拆分,把文本文件拆分成很多个小文件,充分利用我们计算机中
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Microsoft为了利用这个硬件特性,于是在Visual Studio 2010 和 .NET Framework 4的发布及以上版本中,添加了并行编程这个新特性,我想它以后势必会改变我们的开发方式。 在以前或者说现在,我们在并行开发的时候可
c语言输入成绩怎么判断等级
字符型数据在内存中的存储形式是什么
c语言怎么求字符串的长度并输出
c语言函数的三种调用方式是什么
c语言中保留两位小数怎么表示
double的输入格式符是什么