0

ASP.NET Web ページで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: UdtTypeName プロパティを UDT パラメーターに設定する必要があります」という結果になります。投げられる

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 に答える