我已经多次阅读这两篇 文章,试图找出一种$expand
在单个实体上使用查询选项的方法,但是在我尝试过的每一种方式中,我似乎都无法让它工作. 所有其他查询选项都有效,$expand
目前也适用于收集结果。
模型:玩家实体有一个名为 Stats 的导航属性,其中每个对象都包含该玩家在给定年份的统计数据。
我以这种方式设置了 OData:
config.EnableQuerySupport();
ODataModelBuilder modelBuilder = new ODataConventionModelBuilder();
modelBuilder.EntitySet<Player>("OPlayer");
modelBuilder.EntitySet<PlayerStatistics>("OPlayerStats");
Microsoft.Data.Edm.IEdmModel model = modelBuilder.GetEdmModel();
config.Routes.MapODataRoute("ODataRoute", "odata", model);
最初,我是这样设置控制器的:
public class OPlayerController : EntitySetController<Player, int>
{
private readonly DatabaseContext _db = new DatabaseContext();
protected override Player GetEntityByKey(int key)
{
return _db.Players.FirstOrDefault(p => p.PlayerId == key);
}
public override IQueryable<Player> Get()
{
return _db.Players.AsQueryable();
}
protected override void Dispose(bool disposing)
{
_db.Dispose();
base.Dispose(disposing);
}
}
使用此配置,我可以进行以下查询:
/odata/OPlayer(600)
/odata/OPlayer
/odata/OPlayer?$expand=Stats
但显然不是(结果没有展开):
/odata/OPlayer(600)?$expand=Stats
两篇文章都提到,为了支持它,您必须向控制器添加一个方法(操作?),如下所示:
[Queryable]
public SingleResult<Player> GetPlayer(int id)
{
return SingleResult.Create(_dbContext.Players.Where(c => c.ID == id);
}
当我将它添加到我的控制器时,两者/odata/OPlayer(600)
都/odata/OPlayer(600)?$expand=Stats
返回No action was found on the controller 'OPlayer' that matches the request.
任何人都可以提供说明或提供指示以支持$expand
单个实体吗?