1

我正在尝试计算预算减去费用并将其显示在视图中。我有计算工作,但我坚持如何将结果合并到我的视图中。现在我收到错误:

EntityType TETSModel.Project不使用名称 data 声明导航属性。

没有声明projects = from s in db.Projects.Include(p => data) select s;这可以正常工作,但不会显示余额。

有人可以告诉我如何做到这一点吗?

从控制器:

public ViewResult Index()
{
    var data = (from p in db.Projects
                join ex in db.ExpenseItems on p.ProjectKEY equals ex.ProjectKEY
                group ex by p into exgroup
                select new Classes.Budget
                {
                ProjectKEY = exgroup.Key.ProjectKEY,
                OverallBudgetMinusExpenses = exgroup.Key.OverallTechnologyBudget - exgroup.Sum(g => g.ExpenseAmount),
                CurrentBudgetMinusExpenses = exgroup.Key.CurrentPeriodBudget - exgroup.Sum(g => g.ExpenseAmount)
                    });
    var projects = from s in db.Projects.Include(p => p.ContractType).Include(p => p.Division)
               select s;
    projects = from s in db.Projects.Include(p => data)
               select s;
    return View(projects.ToList());
}

在视图中:

@model IEnumerable<TETS_DAL.Project>

@{
ViewBag.Title = "Projects";
}
<h2>All Projects</h2>
<p>
@Html.ActionLink("Create New Project", "Create")
</p>
@using (Html.BeginForm())
{
    <table style="padding: 5px 5px 5px 5px;">
    <tr>
        <th>
            <!--@Html.DisplayNameFor(model => model.ProjectKEY)-->
        </th>
        <th>Project<br />
            Number
        </th>
        <th>Office
        </th>
        <th>Project<br />
            Description
        </th>
        <th>Start<br />
            Date
        </th>
        <th>End<br />
            Date
        </th>
        <th>Current<br />
            Period<br />
            Start
        </th>
        <th>Current<br />
            Period<br />
            End
        </th>
        <th>Total<br />
            Budget
        </th>
        <th>Total<br />
            Budget<br />
            Balance
        </th>
        <th>Current<br />
            Budget
        </th>
        <th>Current<br />
            Budget<br />
            Balance
        </th>
        <th></th>
    </tr>

    @foreach (var item in Model)
    {
        <tr>
            <td>
                @Html.HiddenFor(modelItem => item.ProjectKEY)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.ProjectNumber)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.Division.DivisionName)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.ProjectDescription)
            </td>
            <td>
                @String.Format("{0:d}", item.StartDate)
            </td>
            <td>
                @String.Format("{0:d}", item.OverallEndDate)
            </td>
            <td>
                @String.Format("{0:d}", item.CurrentPeriodStartDate)
            </td>
            <td>
                @String.Format("{0:d}", item.CurrentPeriodEndDate)
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.OverallTechnologyBudget)
            </td>
            <td>
                @*  @Html.DisplayFor(modelItem => item.ExpenseItem.ExpenseAmount)*@
            </td>
            <td>
                @Html.DisplayFor(modelItem => item.CurrentPeriodBudget)
            </td>
            <td>

            </td>
            <td>
            @Html.ActionLink("Edit", "Edit", new { id = item.ProjectKEY }) |
            @Html.ActionLink("Details", "Details", new { id = item.ProjectKEY }) |
            @Html.ActionLink("Expenses", "Index", "ExpenseItem", new { projectSearchString = item.ProjectNumber }, null)
            </td>
        </tr>
    }
</table>

}

预算类:

public class Budget
{
[Key]
public int ProjectKEY { get; set; }
public decimal? OverallBudgetMinusExpenses { get; set; }
public decimal? CurrentBudget { get; set; }
public decimal? CurrentBudgetMinusExpenses { get; set; }
public decimal? OverallBudget { get; set; }
}

项目模型:

namespace TETS_DAL
{
using System;
using System.Collections.Generic;

public partial class Project
{
    public Project()
    {
        this.ExpenseItems = new HashSet<ExpenseItem>();
    }

    public int ProjectKEY { get; set; }
    public Nullable<int> DivisionKEY { get; set; }
    public Nullable<int> ContractTypeKEY { get; set; }
    public string ProjectNumber { get; set; }
    public string ProjectDescription { get; set; }
    public Nullable<System.DateTime> StartDate { get; set; }
    public Nullable<System.DateTime> OverallEndDate { get; set; }
    public Nullable<System.DateTime> CurrentPeriodStartDate { get; set; }
    public Nullable<System.DateTime> CurrentPeriodEndDate { get; set; }
    public Nullable<decimal> OverallTechnologyBudget { get; set; }
    public Nullable<decimal> CurrentPeriodBudget { get; set; }
    public string Notes { get; set; }
    public Nullable<System.DateTime> CreateDate { get; set; }
    public Nullable<bool> Archive { get; set; }
    public Nullable<System.DateTime> LastUpdate { get; set; }
    public byte[] ts { get; set; }

    public virtual ContractType ContractType { get; set; }
    public virtual Division Division { get; set; }
    public virtual ICollection<ExpenseItem> ExpenseItems { get; set; }
}
}
4

1 回答 1

9

你有这些行:

var projects = from s in db.Projects.Include(p => p.ContractType).Include(p => p.Division)
           select s;
projects = from s in db.Projects.Include(p => data)
           select s;

为什么要分配给变量projects两次?

此外,正如您对问题的评论中所述,lambda 表达式p => data说:“对于每个p,返回其data属性。” 但是,根据您收到的错误消息,该Project类型没有名为data. 这就是您收到错误消息的原因。

但我想我明白你在做什么。您想在模型中同时拥有来自变量数据的Project对象和项目吗?Budget您可能需要定义另一个包含 Project 属性和 Budget 属性的类:

public ProjectViewModel
{
    Project Project { get;set;}
    Budget Budget { get;set;}
}

...并编写一两行 LINQ 以ProjectViewModelprojectsand创建对象集合data,加入(我假设)ProjectKEY它们共有的属性。

于 2013-07-08T19:16:30.630 回答