使用的软件:
考虑以下模型:
位置(Id,LocationName,Street,PostalCodeId)
PostalCode(Id,ZIP)
一个位置有一个邮递区号和邮编有许多位置.
这是OData配置:
ODataModelBuilder builder = new ODataConventionModelBuilder();
builder.EntitySet<Location>("Locations");
builder.EntitySet<PostalCode>("PostalCodes");
config.MapODataServiceRoute(
routeName: "ODataRoute",
routePrefix: "odata",
model: builder.GetEdmModel());
Run Code Online (Sandbox Code Playgroud)
型号类:
public class Location {
[Key]
public int Id { get; set; }
public String LocationName { get; set; }
public String Street { get; set; }
public int PostalCodeId { get; set; }
[ForeignKey("PostalCodeId")]
public PostalCode PostalCode { get; set; }
}
public class PostalCode {
public int Id { get; set; }
public string ZIP { get; set; }
public List<Location> Locations { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
http://localhost:49938/odata/Locations?$expand=PostalCode&$orderby=LocationName在浏览器中调用$ expand工作:
{
"@odata.context": "http://localhost:49938/odata/$metadata#Locations",
"value": [
{
"Id": 1,
"LocationName": "My Location 1",
"Street": "Street 7",
"PostalCodeId": 1838,
"PostalCode": {
"Id": 1838,
"ZIP": "4081"
}
}
]
}
Run Code Online (Sandbox Code Playgroud)
但是当我在应用程序中执行相同的请求时,它不起作用:
Container c = new Container(new Uri("http://localhost:49938/odata/"));
var result = c.Locations
.Expand(x => x.PostalCode)
.OrderBy(x => x.LocationName)
.ToList();
Run Code Online (Sandbox Code Playgroud)
当我执行这个代码PostalCode是null.
Martinaut
有没有之间的任何查询操作new Container...和var result= ...?
如果是,请添加以下代码:
container.MergeOption = MergeOption.OverwriteChanges;
Run Code Online (Sandbox Code Playgroud)
谢谢.
| 归档时间: |
|
| 查看次数: |
864 次 |
| 最近记录: |