首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >List<Diary_Entry> DiaryEntry无法转换为collections.generic.list

List<Diary_Entry> DiaryEntry无法转换为collections.generic.list
EN

Stack Overflow用户
提问于 2013-02-24 03:12:02
回答 2查看 50关注 0票数 0
代码语言:javascript
复制
List<Diary_Entry> DiaryEntry = new List<Diary_Entry>();

DiaryEntry = (from DE in db.Diary_Entries
    where DE.Site_Id == 1
    && DE.Date == tempDate
    select DE).ToList().FirstOrDefault();

错误:无法将类型Diary_Entry隐式转换为System.Collections.Generic.List<Diary_Entry>

有人能告诉我如何解决这个问题吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-02-24 03:17:14

您需要删除FirstOrDefault()调用。它返回单个实体,而您的DiaryEntry实例是一个列表。它应该是这样的(DiaryEntry的类型是List<Diary_Entry>):

代码语言:javascript
复制
var DiaryEntry = (from DE in db.Diary_Entries
                  where DE.Site_Id == 1
                  && DE.Date == tempDate
                  select DE).ToList();

或者应该是这样(DiaryEntry的类型是Diary_Entry):

代码语言:javascript
复制
var DiaryEntry = (from DE in db.Diary_Entries
                  where DE.Site_Id == 1
                  && DE.Date == tempDate
                  select DE).ToList().FirstOrDefault();
票数 1
EN

Stack Overflow用户

发布于 2013-02-24 03:19:06

您的变量DiaryEntry的类型为List,但您尝试将其设置为等于Diary_Entry类型的变量。你应该使用

代码语言:javascript
复制
List<Diary_Entry> DiaryEntry = new List<Diary_Entry>();
DiaryEntry = (from DE in db.Diary_Entries
                      where DE.Site_Id == 1
                      && DE.Date == tempDate
                      select DE).ToList();

此查询返回Diary_Entry类型的值列表。如果想要获得Diary_Entry类型的单个值,应该使用

代码语言:javascript
复制
 var DiaryEntry = (from DE in db.Diary_Entries
                          where DE.Site_Id == 1
                          && DE.Date == tempDate
                          select DE).FirstOrDefault();

在这个查询中,您不应该使用ToList()

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15044480

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档