場景是這樣的:Order下有一個Suppler的集合,即一個訂單下可能有多個供應商;Supplier下有一個Product的集合,即對一個供應商采購多個產品。
需求是這樣的:算出所有訂購產品的總價
模型這樣:
public class Order { public int OrderId { get; set; } public ICollection<Supplier> Suppliers { get; set; } public Order() { Suppliers = new List<Supplier>(); } } public class Supplier { public int SupplierId { get; set; } public ICollection<Product> Products { get; set; } public Supplier() { Products = new List<Product>(); } } public class Product { public int ProductId { get; set; } public decimal UnitPrice { get; set; } public int Quantity { get; set; } }
這樣算出總價:
static void Main(string[] args) { var orders = new List<Order> { new Order { OrderId = 1, Suppliers = new List<Supplier> { new Supplier {SupplierId=11, Products= new List<Product> { new Product {ProductId=111, Quantity=1, UnitPrice=10 }, new Product {ProductId = 112, Quantity =1, UnitPrice = 20 } } }, new Supplier {SupplierId =12, Products = new List<Product> { new Product {ProductId =113, Quantity =2, UnitPrice=30 }, new Product {ProductId=114, Quantity=1, UnitPrice=50 } } } } } }; var suppliers = orders.Select(t => t.Suppliers); var productTotalPrice = suppliers.Sum(t => t.Sum(p => p.Products.Sum(o => o.Quantity * o.UnitPrice))); Console.WriteLine(productTotalPrice); Console.ReadKey(); }