我是 C# 的初学者,在做我的项目时遇到了一些麻烦。我在连接到数据库的 Windows 窗体中有 DataGrid
。要编辑数据库中的记录,我必须在数据网格上选择它。我写了选择代码,这里是。
public BugDescriptor GetSelectedBug()
{
BugDescriptor selectedBug = null;
if (ctlBugs.SelectedRows.Count > 0)
{
selectedBug = (BugDescriptor) ctlBugs.SelectedRows[0].DataBoundItem;
}
if (ctlBugs.SelectedCells.Count > 0)
{
selectedBug = (BugDescriptor) ctlBugs.SelectedCells[0].OwningRow.DataBoundItem;
}
return selectedBug;
}
所以,ctlBugs
是我的数据网格的名称,BugDescriptor
是类,描述数据库中记录的字段。
当我尝试调试时出现异常:无法将类型为“System.Data.Entity.DynamicProxies.Bug_ED6497CD7603C9E48A4F28CF92AF30E4A88B104DE0AC6FAF0D12F034495FF727”的对象转换为类型“BugTrackingSystem.BugDescriptor
。
我做错了什么?问我是否需要告诉我有关我的代码的其他信息。
P. S. 我已经阅读了一些类似问题的答案,但无法理解如何在遇到麻烦时使用它们。
最佳答案
如果你想禁用 DynamicProxies:
dbContext.Configuration.ProxyCreationEnabled = false;
在 EF 4 中
objectContext.ContextOptions.ProxyCreationEnabled = false;
但是在使用linq时需要调用“include”。
关于c# - 无法将类型为 'System.Data.Entity.DynamicProxies' 的对象转换为类型 'BugTrackingSystem.BugDescriptor',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23157553/