0

如果 ASP.NET 网页使用ObjectDataSource,您可以将其配置为使用使用表值参数的存储过程吗?

用户自定义类型:

CREATE TYPE [dbo].[integer_list_tbltype] AS TABLE
(
 [n] [int] NOT NULL,
 PRIMARY KEY CLUSTERED 
)

存储过程:

CREATE PROCEDURE [dbo].[GeneralReport]  
@intList integer_list_tbltype READONLY
AS
BEGIN
    SELECT * FROM ...
END

ASP.NET

<asp:ObjectDataSource ID="GeneralDataSource" runat="server" 
    SelectMethod="GetDataByRange" 
    TypeName="MyProject.GeneralDataSetTableAdapters.GeneralViewTableAdapter" 
    >
    <SelectParameters>
        <asp:Parameter Name="intList" />            
    </SelectParameters>
</asp:ObjectDataSource>

我尝试像这样连接到 ObjectDataSource 的 Selecting 事件:

protected void GeneralDataSource_Selecting( object sender, System.Web.UI.WebControls.ObjectDataSourceSelectingEventArgs e )
{
    var zeroList = new List<SqlDataRecord>();
    var tvp_definition = new[] {new SqlMetaData( "n", SqlDbType.Int )};
    var sqlDataRecord = new SqlDataRecord( tvp_definition );
    sqlDataRecord.SetInt32( 0, 0 );

    zeroList.Add( sqlDataRecord  );

    e.InputParameters[ "intList" ] = zeroList;        
}

但这只会导致“System.ArgumentException:必须为 UDT 参数设置 UdtTypeName 属性”。被抛出

4

2 回答 2

1

我不知道你为什么要这样做。请参阅 Lenni Lobel 的这篇文,看看它是否适合您。

*更新: *对于报告,我使用Codebetter.com 上显示的这种技术

于 2010-10-15T03:52:58.027 回答
0

为了完整起见,这是一个可能的解决方案(尽管它可能确实属于“可怕”类别!)

覆盖由强类型数据集生成的表适配器。例如。

public class GeneralViewTableAdapter2 : GeneralViewTableAdapter
{
    public override GeneralDataSet.GeneralViewDataTable GetDataByRange( object intList )
    {
        try
        {
            return base.GetDataByRange( intList );
        }
        catch ( ArgumentException e )
        {
            foreach ( SqlParameter parameter in this.Adapter.SelectCommand.Parameters )
            {
                if ( parameter.SqlDbType == SqlDbType.Structured )
                    parameter.TypeName = "integer_list_tbltype";
            }

            return base.GetDataByRange( intList );
        }
    }
}

然后更新 ObjectDataSource 控件上的 Type 属性以引用这个新类。例如。“MyProject.GeneralDataSetTableAdapters.GeneralViewTableAdapter2”

希望看到比这更“干净”的答案!

于 2010-10-15T05:51:51.990 回答