Я новичок в ASP.NET, и я пытаюсь реализовать собственный метод Insert Object Object DataSource. Бизнес-метод по умолчанию работает отлично (с одним параметром объекта). Однако, когда я добавляю дополнительный параметр, бизнес-метод не вызывается.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», он вызывает вызов вместе с событием. Также, если я удалю параметр p из InsertWithParams, он будет вызван.
<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>
Так что в этом случае я не могу добавить параметры в метод insert в объекте ObjectDataSource. Добавление или удаление объявленных InsertParameters, похоже, не имеет значения.
Да, после удаления ObjectTypeName = "Business.MyObject" из декларации DataSource, звонки приходят через. – Justicle