【发布时间】:2011-01-12 10:14:12
【问题描述】:
我是 ASP.NET 的新手,我正在尝试实现自定义 ObjectDataSource Insert 方法。 默认业务方法工作正常(使用单个对象参数)。但是,当我添加一个额外的参数时,业务方法不会被调用。
这是我的代码 - Insert() 总是被调用,但 InsertWithParams() 永远不会。
// Business Layer
public class MyObject
{
public MyObject() {}
public string Foo { get; set;}
}
namespace MyLogic {
public static Insert(MyObject m)
{
// ... do DB insert
}
public static InsertWithParams(MyObject m, string p)
{
// ... do more fancy DB insert
}
} // MyLogic
鉴于以下 ObjectDataSource 声明,永远不会调用“InsertWithParams”和“MyObjectDS_Inserting”。
但是,如果改为指定“MyLogic.Insert”,它会与事件一起被调用。此外,如果我从 InsertWithParams 中删除 p 参数,它确实会被调用。
<asp:ObjectDataSource runat="server" ID="MyObjectDS"
TypeName="Business.MyLogic"
DataObjectTypeName="Business.MyObject"
InsertMethod="InsertWithParams"
OnInserting="MyObjectDS_Inserting"
>
<InsertParameters>
<asp:Parameter Name="m" Type="Object" />
<asp:Parameter Name="p" Type="String" />
</InsertParameters>
</asp:ObjectDataSource>
所以在这种情况下,我似乎无法将参数添加到 ObjectDataSource 中的插入方法。 添加或删除声明的 InsertParameters 似乎没有什么区别。
【问题讨论】: