ObjectDataSource не вызывает метод Insert, если у него есть дополнительные параметры - PullRequest
3 голосов
/ 03 февраля 2010

Я новичок в 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», он вызывается вместе с событием.Кроме того, если я удаляю параметр 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>

Так что в этом случае кажется, что я не могу добавить параметры в метод вставки в ObjectDataSource.Добавление или удаление объявленных InsertParameters, похоже, не имеет значения.

1 Ответ

4 голосов
/ 03 февраля 2010

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

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

...