public class DbContextHelper<T> where T : DbContext, new() { private static T _instance; public static T Instance { get { return _instance ?? (_instance = new T()); } } public static void Add<TEntity>(TEntity entity) where TEntity : class { using(var context = _instance) { context.Set<TEntity>().Add(entity); context.SaveChanges(); } } public static void Update<TEntity>(TEntity entity) where TEntity : class { using(var context = _instance) { context.Entry(entity).State = EntityState.Modified; context.SaveChanges(); } } public static void Delete<TEntity>(TEntity entity) where TEntity: class { using(var context = _instance) { context.Set<TEntity>().Add(entity); context.SaveChanges(); } } public static List<TEntity> GetAll<TEntity>() where TEntity : class { using (var context = _instance) { return context.Set<TEntity>().ToList(); } } public static TEntity GetById<TEntity>(object id) where TEntity : class { using (var context = _instance) { return context.Set<TEntity>().Find(id); } }如何通过导航属性获取信息
时间: 2024-01-11 11:03:15 浏览: 131
报告如何使用aspnet mvc查询生成器向gridview扩展t624853提供数据.zip
可以通过导航属性来获取相关联实体的信息。
假设有两个实体类:Order 和 Customer,Order 实体类中有一个 Customer 属性表示该订单所属的客户,可以通过该属性来获取客户信息。
首先,在 Order 实体类中添加一个名为 Customer 的导航属性:
```
public class Order
{
public int OrderId { get; set; }
public int CustomerId { get; set; }
public decimal Amount { get; set; }
public virtual Customer Customer { get; set; }
}
```
然后,在 DbContextHelper 类中添加一个方法来获取所有订单及其所属的客户信息:
```
public static List<Order> GetAllOrdersWithCustomers()
{
using (var context = _instance)
{
return context.Orders.Include(o => o.Customer).ToList();
}
}
```
在这个方法中,使用 Include 方法来指定要加载的导航属性,然后调用 ToList 方法返回包含所有订单及其所属客户信息的列表。
可以通过调用该方法来获取所有订单及其所属客户信息:
```
var orders = DbContextHelper<Order>.GetAllOrdersWithCustomers();
foreach (var order in orders)
{
Console.WriteLine("Order Id: {0}, Amount: {1}, Customer Name: {2}",
order.OrderId, order.Amount, order.Customer.Name);
}
```
在这个示例中,遍历所有订单并输出订单号、金额和客户姓名。请注意,由于使用了 Include 方法来加载 Customer 导航属性,因此可以访问该属性中的所有属性,例如客户的姓名。
阅读全文