前提:
AspxGridView + ObjectDataSource + ADO.Net EntityFramework
实现功能:
表格内编辑数据
触发表格更新事件报错:
完整错误信息如下
ObjectDataSource '_DataSource' could not find a non-generic method 'Update' that has parameters: item, original_item, original_Id.
原因:
由于此次需求没有新增数据功能,只有修改现有数据的功能,所以Datasource对应的操作类中没有Insert方法,只为数据源设置了SelectMethod 与 UpdateMethod,
这样就造成,数据源没有DataObjectTypeName信息
如下:
<asp:ObjectDataSource ID="_WeekClassTimeDataSource" runat="server" ConflictDetection="CompareAllValues"
OldValuesParameterFormatString="original_{0}" SelectMethod="GetAll"
TypeName="XXX.XXX.TestRepository"
UpdateMethod="Update">
</asp:ObjectDataSource>
当数据源执行更新方法的时候,从而把更新方法认为是面向参数的更新方法,而不是对象参数的更新方法,从而报错
解决方式:
手动添加DataObjectTypeName信息 修改后如下:
<asp:ObjectDataSource ID="_WeekClassTimeDataSource" runat="server" ConflictDetection="CompareAllValues"
OldValuesParameterFormatString="original_{0}" SelectMethod="GetAll"
TypeName="XXX.XXX.TestRepository"
UpdateMethod="Update" DataObjectTypeName="XXX.XXX.Test">
</asp:ObjectDataSource>