带有实体框架的Linq
本文关键字:Linq 框架 实体 | 更新日期: 2023-09-27 18:30:13
我是LINQ和实体框架的新手,希望能就以下场景提供一些建议。
我有一个带有两个表的实体模型。
Travel_Request和资源
样本字段
Travel_Request
Request_ID
Resource_ID
资源
Resource_ID
Resource_Name
我想在返回所有TRAVEL_REQUESTS 时将Resource_Name添加到列表中
提前感谢
嗨,您需要使用Linq join:
var data = from t in Travel_Request
join r in Resource on t.Resource_ID equals r.Resource_ID
select new
{
RequestId = t.Request_ID,
ResourceId = t.Resource_ID,
ResourceName = r.Resource_Name
};
如果你已经有EF关联,那么它可能只是:
var data = from t in Travel_Request
select new
{
RequestId = t.Request_ID,
ResourceId = t.Resource_ID,
ResourceName = t.Resource.Resource_Name
};
您将不得不创建一个类似这样的新对象。
var data = Travel_Request.Select(s=> new { Resource_Name = s.Recource.Resource_Name, Request_ID = s.Request_ID, Resource_ID = s.Resource_ID}).ToList();
只要我正确理解了这个问题,它就会起作用。
您可以查询Travel_Request实体并使用导航属性来执行此操作。
var resultList = DbContext.Travel_Request.Resources.where(x=>x.Resource_Name =="Your string").ToList();
我会添加一个同时拥有这三种功能的模型,然后执行类似的操作。
var TravelRequests =
from p in Travel_Request
from r in Resource.where(Res => Res.Resource_ID == p.Resource_ID)
select new TravelModel{
requestID = p.requestID,
Resource_ID = p.Resource_ID,
ResourceName = r.ResourceName
};
但这只是我将如何做的一个例子,也许还有更好的方法。此外,语法可能有点偏离,但总体思路是存在的。
使用Join:
Travel_Request.Join(Resource, tr => tr.ResourceId, r => r.ResourceId, (tr, r) => new { RequestId = tr.RequestId, ResourceId = tr.ResourceId, Name = r.ResourceName})
或者,更好的做法是在TravelRequest中添加Navigation属性。TravelRequest看起来是这样的:
int RequestId { get; set; }
int ResourceId{ get; set; }
[ForeignKey("ResourceId")]
Resource Resource { get; set; }
通过这种方式,您可以使用Include
DBContext.TravelRequests.Include("Resource").First().Resource.Name;
Include告诉EF使用TravelerRequest 获取资源