asp.net - 当 ObjectDataSource 有额外参数时不调用 Insert 方法

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

最佳答案

I also had trouble inserting record, however, I found out after testing for a while and google a bit, that if your specify 'DataObjectTypeName' parameter in ObjectDataSource, InsertParameters get ignored. So I just don't specify that, and it works for me.

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

关于asp.net - 当 ObjectDataSource 有额外参数时不调用 Insert 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2188793/

相关文章:

c# - 如何阻止我的 ObjectDataSource 绑定(bind)两次?

asp.net - ObjectDataSource 没有要插入的值

c# - 从类型注释列表中获取不同的值

c# - Asp.Net WebApi OWIN 身份验证

asp.net - 隐藏 Kendo UI DatePicker 文本框

asp.net - 处理ASP.NET中的服务器错误

.net - VB.Net : How to use an Object data source in report (. RDLC)

c# - 使用 ObjectDataSource 和 DataObjectTypeName,如何处理只有一个 Id 参数的删除方法?

asp.net - 对象数据源选择方法在代码调用中不返回任何内容

c# - Telerik getting selected ID(从 Radgrid selected item 获取数据)