Выполнить запрос Sql в рамках сущности - PullRequest
0 голосов
/ 05 марта 2019

У меня есть таблица данных jquery, в которой я хочу показать сводный отчет, сгенерированный из SQL-запроса, но я не могу это сделать, он показывает ошибку в запросе.Сводный отчет состоит из всех названий месяцев и количества записей в каждом месяце.

Ошибка:

System.Data.Entity.Core.EntityCommandExecutionException: «Средство чтения данных несовместимо суказанный 'DHIFeedbackModel.FeedBack'.Элемент типа «FeedbackUserName» не имеет соответствующего столбца в считывателе данных с тем же именем. '

public ActionResult LoadData()
{
    using (DHIFeedbackEntities2 Ms = new DHIFeedbackEntities2())
    {

        //var summary = Ms.FeedBacks.SqlQuery("select * from [DHIFeedback].[dbo].[FeedBack]").ToList<FeedBack>();
        var summary = Ms.FeedBacks.SqlQuery(
            @"SELECT * 
            FROM 
                (
                SELECT 
                    YEAR([FeedBackDate])[Year],DATENAME(MONTH, [FeedBackDate])[Month],
                    COUNT(1)[FeedbackID] 
                FROM 
                    [DHIFeedback].[dbo].[FeedBack] 
                GROUP BY 
                    YEAR([FeedBackDate]
                ),
                DATENAME(MONTH, [FeedBackDate])) AS Monthlyupdate 
                PIVOT(SUM([FeedbackID]) FOR Month IN([January],[February],[March],[April],[May],[June],[July],[August],[September],[October],[November],[December])) AS MNamePivot 
            order by 1,2"
        ).FirstOrDefault<FeedBack>();
        return Json(new { data = summary }, JsonRequestBehavior.AllowGet);


    }
}

и javascript:

$(document).ready(function () {
            $('#Summary').DataTable({

                "processing": true,

                "ajax": {
                    "url": "/Summary/LoadData",
                    "type": "GET",
                    "datatype": "json",

                },
                "lengthMenu": [
                    [5, 10, 25, 50, 100, -1],
                    [5, 10, 25, 50, 100, "All"]
                ],
                "autoWidth": true,
                "responsive": true,
                "lengthChange": true,
                "ordering": true,
                "fnRowCallback": function (nRow, aData, iDisplayIndex) {
                    var oSettings = this.fnSettings();
                    $("td:first", nRow).html(oSettings._iDisplayStart + iDisplayIndex + 1);
                    return nRow;
                },
                "columns": [

                    { "data":"Year", "autoWidth": true },
                    { "data":"January", "autoWidth": true },
                    { "data":"February", "autoWidth": true },
                    { "data":"March", "autoWidth": true },
                    { "data":"April", "autoWidth": true },
                    { "data":"May", "autoWidth": true },
                    { "data":"June", "autoWidth": true },
                    { "data":"July", "autoWidth": true },
                    { "data":"August", "autoWidth": true },
                    { "data":"September", "autoWidth": true },
                    { "data":"October", "autoWidth": true },
                    { "data":"November", "autoWidth": true },
                    { "data":"December", "autoWidth": true }
                ]
            });
        });


 public partial class FeedBack
    {
        public int FeedbackID { get; set; }
        public string FeedbackUserName { get; set; }
        public string FeedBackUserEmailID { get; set; }
        public string FeedBackComment { get; set; }
        public string Designation { get; set; }
        public string Organization { get; set; }
        public string ContactNo { get; set; }
        public string City { get; set; }
        public Nullable<System.DateTime> FeedBackDate { get; set; }
        public Nullable<double> IsPublished { get; set; }
        public string Reply { get; set; }
        public Nullable<double> IsReplied { get; set; }
        public Nullable<System.DateTime> ReplyDate { get; set; }
        public string ReplyBy { get; set; }
        public string Sector { get; set; }
        public Nullable<int> Status { get; set; }

        public int Year { get; set; }
        public int January { get; set; }
        public int February { get; set; }
        public int March { get; set; }
        public int April { get; set; }
        public int May { get; set; }
        public int June { get; set; }
        public int July { get; set; }
        public int August { get; set; }
        public int September { get; set; }
        public int October { get; set; }
        public int November { get; set; }
        public int December { get; set; }
        public string Monthlyupdate { get; set; }
        public string Month{ get; set; }
        [NotMapped]
        public List<FeedBack> FeedBackCollection { get; set; }

1 Ответ

0 голосов
/ 05 марта 2019

ошибка означает, что ORM ожидает набор результатов, включающий все без исключения свойства FeedBacks, включая имя с именем FeedbackUserName

Так что вам нужно отредактировать предложение select вашего sql, чтобы оно возвращало всеожидаемые столбцы.

или вы можете использовать

Ms.Database.SqlQuery<SomeType>(
                   "your query here").ToList();

, где SomeType равно:

public class SomeType {
    public int Year {get; set;}        
    //... and/or all the pivoted columns
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...