ObjectDataSource在有额外参数时不调用Insert方法

时间:2010-02-03 00:19:51

标签: asp.net objectdatasource

我是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中向insert方法添加参数。 添加或删除声明的InsertParameters似乎没有什么区别。

1 个答案:

答案 0 :(得分:4)

  

我也无法插入记录,但是,经过一段时间的测试后我发现了google,如果你在ObjectDataSource中指定'DataObjectTypeName'参数,InsertParameters会被忽略。所以我只是不指定它,它对我有用。

从这里开始:http://www.velocityreviews.com/forums/t297725-objectdatasource-has-no-values-to-insert-error.html