2010-02-03 4 views
3

Я новичок в 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, похоже, не имеет значения.

ответ

4

У меня также были проблемы с установкой записи, однако, я узнал, что после тестирования на некоторое время и Google немного, что если ваш указать параметр «DataObjectTypeName» в ObjectDataSource, InsertParameters игнорируются. Поэтому я просто не указываю это, и это работает для меня.

Отсюда: http://www.velocityreviews.com/forums/t297725-objectdatasource-has-no-values-to-insert-error.html

+1

Да, после удаления ObjectTypeName = "Business.MyObject" из декларации DataSource, звонки приходят через. – Justicle