0

我正在创建一个新的 ViewModel 来统计调查结果,对该数据执行一些计算,然后将新计算返回到视图。我无法弄清楚如何在集合中包含常规的“字符串”数据。

 var data = from SurveyResponseModel in db.SurveyResponseModels
                       group SurveyResponseModel by SurveyResponseModel.MemberId into resultCount
                       select new ResultsViewModel()
                       {
                           MemberId = resultCount.Key,

                           UseNewTreatmentResult = db.SurveyResponseModels.Count(r => r.UseNewTreatment),
                           UseBetterTechniqueResult = db.SurveyResponseModels.Count(r => r.UseBetterTechnique),
                           ChangesOthersResult = db.SurveyResponseModels.First(r => r.ChangesOthers),

                       };
            return View(data);

第一部分是计算布尔响应并将它们作为整数传递回 ViewModel。包含的部分ChangesOthersResult = db.SurveyResponseModels.First(r => r.ChangesOthers),应该只从模型中选择字符串并传递给 ViewModel。我目前收到有关从字符串类型更改为布尔类型的语法错误。我不确定这是什么语法。

    public class SurveyResponseModel
    {
        [Key]
        public int ResponseId { get; set; }

        public int MemberId { get; set; }

        public int ProgramId { get; set; }


        [DisplayName("Use a new treatment")]
        public bool UseNewTreatment { get; set; }

        [DisplayName("Use better/more updated technique")]
        public bool UseBetterTechnique { get; set; }

        [DisplayName("Other (please specify):")]
        public string ChangesOthers { get; set; }



    }










 public class ResultsViewModel
    {

        public int MemberId { get; set; }

        public int ProgramId { get; set; }


        [DisplayName("Use a new treatment")]
        public int UseNewTreatmentResult { get; set; }

        [DisplayName("Use better/more updated technique")]
        public int UseBetterTechniqueResult { get; set; }

        [DisplayName("Other (please specify):")]
        public string ChangesOthersResult { get; set; }


    }
4

1 回答 1

2

你需要:

ChangesOthersResult = db.SurveyResponseModels.Select(r => r.ChangesOthers)

SelectManyFirstOrDefault()最终根据类型ChangesOthersResult和您实际想要选择的内容添加到最后。

Select给你一个“集合的集合”(我假设这ChangesOthers是一个集合类型)。SelectMany集合的通用类型的“扁平集合” ChangesOthers。添加FirstOrDefault()afterSelect为您提供第一个SurveyResponseModels实体的单个集合 - 或null.

编辑

在您提供类之后,我看到它不是集合,ChangesOthersChangesOthersResult只是 type string。所以该行应该是:

ChangesOthersResult = db.SurveyResponseModels.Select(r => r.ChangesOthers)
    .FirstOrDefault()
于 2012-06-22T16:14:47.360 回答