我有一个 C# EF 6 Database First 项目(“DocRetData”),我在 VB.Net Web Forms 项目中用作我的“模型”。我也在使用“Web Forms Scafolding”扩展。我添加了对 EF 项目的引用,然后创建了“New Scaffold Item”。项目编译。当我运行它并访问“默认”页面时,它列出的项目很好,但是当我去编辑或创建一个新项目时,我在 ForeignKey_EditField 类的 GetData() 函数中得到 System.ArgumentNullException。它看起来像这样:
Public Function GetData() As IQueryable
Dim entityType = Type.[GetType](Me.DataTypeName)
Return _db.[Set](entityType).AsQueryable()
End Function
这必须与某种引用冲突有关,因为如果我删除数据项目,将模型添加为 Web 窗体项目中的一个类并执行所有相同的步骤,那么我不会收到错误并且可以编辑或创建项目就好了。
这里的数据结构相当简单。我在这里尝试引用的表(对象)具有以下结构:
[AppSettingID] [int] IDENTITY(1,1) NOT NULL,
[CountyID] [int] NOT NULL,
[Name] [varchar](30) NOT NULL,
[VariableName] [varchar](50) NOT NULL,
[Setting] [varchar](4000) NOT NULL,
[FieldDataTypeID] [int] NOT NULL,
其中 CountyID 和 FieldDataTypeID 是其他表的外键。
Return 语句上发生错误,因为 entityType 为空。Me.DataTypeName 是“DocRetData.County”。我猜这与 VB.Net 处理/不处理命名空间但无法追踪它的方式有关。
谢谢
dbl