我正在尝试将RIA服务与实体框架后端一起使用。模型由设计师自动生成。 (VS 2010,.NET 4.0,EF 4.0,SilverLight 4.0) 我遇到的问题是在服务层按预期加载了引用属性,但是当该信息传递给SilverLight应用程序时,引用实体变为NULL。
我使用了两种方法来填充参考实体:
public Employee GetEmployeeByID(int employeeID)
{
var result = this.ObjectContext.Employees
.Include("EmployeeRoles")
.Where(emp => emp.EmployeeID == employeeID)
.FirstOrDefault();
return result;
}
和
public Employee GetEmployeeByID(int employeeID)
{
var result = this.ObjectContext.Employees
.Where(emp => emp.EmployeeID == employeeID)
.FirstOrDefault();
if (result != null && result.EmployeeRoleReference.IsLoaded == false)
{
result.EmployeeRoleReference.Load();
}
return result;
}
在返回之前检查对象时,两种方法似乎都正确填充了Reference对象。 但是,当我尝试通过RIA Services从UI引用Employee对象时,EmployeeRole引用的实体为NULL。
在前端我打电话:
public void LoadEmployeeProfile()
{
int empID = WebContext.Current.User.EmployeeID;
LoadOperation<Employee> loadEmployee = _appcontext.Load(_appContext.GetEmployeeByIDQuery(empID));
loadEmployee.Complete += new System.EventHandler(loadEmployee_Completed);
}
void LoadEmployee_Completed(object sender, System.EventArgs e)
{
LoadOperation<Employee> loadEmployee = sender as LoadOperation<Employee>;
if (loadEmployee == null)
return;
loadEmployee.Completed -= LoadEmployee_Completed;
foreach (Employee employee in loadEmployee.Entities)
{
this.EmployeeProfile == employee;
break;
}
}
这似乎是所有教科书类型的东西,但我无法追查导致为什么RIA服务没有像我预期的那样填充参考实体。
答案 0 :(得分:1)
为了澄清,您正在尝试请求Employee记录并包含由数据库/实体模型中的引用链接定义的EmployeeRoles。
在包含Employee元数据的.Web RIA项目中,我会检查您的Employee元数据中是否使用[Include]属性标记了EmployeeRoles。
您需要在查询和模型元数据中包含引用。
希望这有帮助。