Я пытаюсь отобразить данные из двух таблиц, используя 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;
Я изменил равно ==, но тогда он не скомпилируется.