【问题标题】:ObjectDataSource not calling Insert method when it has extra parametersObjectDataSource 有额外参数时不调用 Insert 方法
【发布时间】:2011-01-12 10:14:12
【问题描述】:

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

【问题讨论】:

    标签: asp.net objectdatasource


    【解决方案1】:

    我在插入记录时也遇到了麻烦,但是,我在测试了一段时间后发现,如果您在 ObjectDataSource 中指定“DataObjectTypeName”参数,则 InsertParameters 会被忽略。所以我只是没有具体说明,它对我有用。

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

    【讨论】:

    • 是的,从 DataSource 声明中删除 ObjectTypeName="Business.MyObject" 后,调用就通过了。
    猜你喜欢
    • 1970-01-01
    • 2011-06-19
    • 2018-03-13
    • 1970-01-01
    • 2017-01-27
    • 2018-07-03
    • 2017-02-02
    • 2017-06-01
    • 2011-01-19
    相关资源
    最近更新 更多