Проблема с отображением данных из запроса linq - PullRequest
0 голосов
/ 16 января 2019

Я пытаюсь отобразить данные из двух таблиц, используя linq, ошибки нет, но я думаю, что мои данные не попали в представление. При отладке кода я вижу, что правильная информация обрабатывается linq. После того, как я запустил свое приложение, никакие данные не отображаются только @Html.DisplayNameFor.

var details = from l in db.LogDetails.ToList()
              join a in db.AuditLog.ToList()
                 on l.AuditLogId equals a.AuditLogId into b
              from d in b.DefaultIfEmpty()
              where d.RecordId.Equals(id)
              select new AuditLogDetail
                      {
                          PropertyName = l.PropertyName,
                          OriginalValue = l.OriginalValue,
                          NewValue = l.NewValue
                      };

return View(details.ToList());

Полный просмотр

@model IEnumerable<TrackerEnabledDbContext.Common.Models.AuditLogDetail>

@{
    ViewBag.Title = "Lista zgłoszeń";
}

<h2>Lista zgłoszeń</h2>

<p>
    @Html.ActionLink("Nowe zgłoszenie", "Create")
</p>
<table class="table">
    <tr>
        <th>
            @Html.DisplayNameFor(model => model.PropertyName)

        </th>
        <th>
            @Html.DisplayNameFor(model => model.OriginalValue)

        </th>
        <th>
            @Html.DisplayNameFor(model => model.NewValue)
        </th>

    </tr>

    @foreach (var item in Model)
    {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.PropertyName)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.OriginalValue)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.NewValue)
        </td>
    </tr> 
    }

</table>

Снимок экрана с информацией, которая появляется после отладки возвращаемого представления (details.ToList ());

Я изменил запрос linq на:

var r = from s in db.LogDetails
        select s;

и каждое значение в таблице отображается правильно, но мне нужно отфильтровать данные на основе другой таблицы, поэтому при попытке использования следующего кода возникает ошибка:

Невозможно создать постоянное значение типа 'System.Object'. В этом контексте поддерживаются только примитивные типы или типы перечисления.

Код:

var r = from s in db.LogDetails
        join l in db.AuditLog
             on s.AuditLogId equals l.AuditLogId
        where l.RecordId.Equals(id)
        select s;

Я изменил равно ==, но тогда он не скомпилируется.

1 Ответ

0 голосов
/ 17 января 2019

попробуйте заменить .Equals на ==

    var r = from s in db.LogDetails
    join l in db.AuditLog
         on s.AuditLogId equals l.AuditLogId
    where l.RecordId == id
    select s;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...