Asp.net ObjectDataSource在具有额外参数时不调用插入方法

Asp.net ObjectDataSource在具有额外参数时不调用插入方法,asp.net,objectdatasource,Asp.net,Objectdatasource,我是ASP.NET新手,正在尝试实现一个自定义ObjectDataSource插入方法。 默认的业务方法工作正常(使用单个对象参数)。但是,当我添加一个额外的参数时,不会调用业务方法 <asp:ObjectDataSource runat="server" ID="MyObjectDS" TypeName="Business.MyLogic" DataObjectTypeName="Business.MyObject" InsertMetho

我是ASP.NET新手,正在尝试实现一个自定义ObjectDataSource插入方法。 默认的业务方法工作正常(使用单个对象参数)。但是,当我添加一个额外的参数时,不会调用业务方法

<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()总是被调用,但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中的insert方法添加参数。 添加或删除声明的InsertParameters似乎没有什么区别

我在插入记录时也遇到了问题,然而,我在测试了一段时间后发现,如果在ObjectDataSource中指定'DataObjectTypeName'参数,InsertParameters将被忽略。所以我没有具体说明,这对我来说很有效


从这里:

Yep,从数据源声明中删除ObjectTypeName=“Business.MyObject”后,调用将通过。