moh*_*her 5 c# asp.net-mvc asp.net-mvc-5
我尝试从这个控制器添加视图。我只需要这个视图来显示不用于插入、更新或删除的数据
public ActionResult Index()
{
var CartObj = ShoppingCart.GetCart(this.HttpContext);
var classshop = new New
{
CartItems = CartObj.GetCartItems(),
CartTotal = CartObj.GetSum()
};
return View(classshop);
}
namespace MusicStore.Models
{
public class ShoppingCart
{
MusicStoreEntities dbo = new MusicStoreEntities();
string ShoppingCartID { get; set; }
public const string CartSessionKey = "CartId";
public static ShoppingCart GetCart(HttpContextBase Context)
{
var cart = new ShoppingCart();
cart.ShoppingCartID = cart.GetCardId(Context);
return cart;
}
public static ShoppingCart GetCart(Controller controller)
{
return GetCart(controller.HttpContext);
}
public List<Cart> GetCartItems()
{
return dbo.Carts.Where(a => a.CartId == ShoppingCartID).ToList();
}
public decimal? GetSum()
{
decimal? Sum = (from items in dbo.Carts
where items.CartId == ShoppingCartID
select (int)items.Count * items.album.Price).Sum();
return Sum ?? decimal.Zero;
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后我收到了这个错误:
运行所选代码生成器时出现错误:“无法检索‘Musicstore.Model.new’的元数据在模型生成期间检测到一个或多个验证错误musicstore,models.New :entity type‘New’ has no key defined 。定义 entityType 的键
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace MusicStore.Models
{
public class New
{
public List<Cart> CartItems { get; set; }
public decimal? CartTotal { get; set; }
}
}
Run Code Online (Sandbox Code Playgroud)
这里有两个选择。首先,如果此类映射到数据库中的表,则实体框架中的每个模型都需要一个主键。将其添加到您的模型中:
[Key]
public int Id { get; set; }
Run Code Online (Sandbox Code Playgroud)
这将创建一个名为 的新属性Id,并且该[Key]属性使其成为主键。从技术上讲,您不需要该属性,因为 EF 将获取Id属性并将其用作键,但我更喜欢明确地表示。
或者,如果您不希望此类成为数据库中的表,请NotMapped向该类添加属性,如下所示:
[NotMapped]
public class New
{
public List<Cart> CartItems { get; set; }
public decimal? CartTotal { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4262 次 |
| 最近记录: |