加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – Linq和EF on .Any()

发布时间:2020-12-16 01:42:01 所属栏目:百科 来源:网络整理
导读:我使用c#,linq和EF4. 我在我的概念模型中表示的DataBase中有两个表: 数据库表: CmsContentsCmsCategoriesCmsRelatedCategories (Pure Juction Table) 实体类型: CmsContentCmsCategory Entyt套装: CmsContentsCmsCategories 我有一些导航属性: for CmsC
我使用c#,linq和EF4.

我在我的概念模型中表示的DataBase中有两个表:

数据库表:

CmsContents
CmsCategories
CmsRelatedCategories (Pure Juction Table)

实体类型:

CmsContent
CmsCategory

Entyt套装:

CmsContents
CmsCategories

我有一些导航属性:

for CmsContents --> CmsCategories --> Return Collection of Cms CmsCategory
for CmsCategories --> CmsContents --> Return Collection of Cms CmsContents

数据库中的连接表数据如下:

CategoryId     ContentId
7              1
7              2
9              2

我需要查询Entity Framwork来检索包含在Junction Table中的所有CmsContents.

目前我使用此代码:

var contents = from cnt in context.CmsContents
                               where cnt.CmsCategories.Any()
                               select cnt;

返回:

CmsContents
1
2

我需要显示结果:

CmsContents
1
2
2

我怀疑Any()只显示DISTINCT值,但我需要列出所有值.

知道怎么解决吗?

你能不能给我写LINQ查询,这样我就能得到清晰的图片.

解决方法

Any()根本不返回值 – 它返回一个布尔值,表示集合中是否有任何值.它只显示两个值,因为您只查询CmsContents,它有两行,并且两行至少有一个类别,因此两行都在结果中.

看起来你真的喜欢这样的事情:

var contents = from cnt in context.CmsContents
               from category in cnt.CmsCategories
               select cnt;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读