Dapperストアドプロシージャを使用したテーブル値パラメータ

c# dapper sql-server-2008

質問

私はテーブル値のパラメータを受け入れるストアドプロシージャを呼び出そうとしています。

私はカスタムパラメータ型を実装し、 この質問に関するガイドラインに従っています:

internal class IntDynamicParam
{
    string name;
    IEnumerable<int> numbers;

    public IntDynamicParam(string name,IEnumerable<int> numbers)
    {
        this.name = name;
        this.numbers = numbers;
    }

    public void AddParameters(IDbCommand command)
    {
        var sqlCommand = (SqlCommand)command;
        sqlCommand.CommandType = CommandType.StoredProcedure;

        List<Microsoft.SqlServer.Server.SqlDataRecord> number_list = new List<Microsoft.SqlServer.Server.SqlDataRecord>();

        // Create an SqlMetaData object that describes our table type.
        Microsoft.SqlServer.Server.SqlMetaData[] tvp_definition = { new Microsoft.SqlServer.Server.SqlMetaData("n", SqlDbType.Int) };

        foreach (int n in numbers)
        {
            // Create a new record, using the metadata array above.
            Microsoft.SqlServer.Server.SqlDataRecord rec = new Microsoft.SqlServer.Server.SqlDataRecord(tvp_definition);
            rec.SetInt32(0, n);    // Set the value.
            number_list.Add(rec);      // Add it to the list.
        }

        // Add the table parameter.
        var p = sqlCommand.Parameters.Add("@" +name, SqlDbType.Structured);
        p.Direction = ParameterDirection.Input;
        p.TypeName = "int_list_type";
        p.Value = number_list;

    }
}

これを次のように使用しようとしています:

var p = new DynamicParameters();
 p.AddDynamicParams(new IntDynamicParam("@IDList", new int[] { 1000, 2000, 3000 }));
 p.Add("@StartRow", startRow);
 p.Add("@EndRow", endRow);
 p.Add("@OrderByField", orderByField.ToString());
 p.Add("@OrderBy", orderBy.ToString());
 p.Add("@TotalRows", 0, dbType: DbType.Int32, direction: ParameterDirection.Output);
 var v = cnn.Query<venue>(spName, p,
                    commandType: CommandType.StoredProcedure).ToList<IDBVenueLite>();

ただし、パラメータ ' @IDList 'は渡されません。明らかにAddDynamicParamsは行く方法ではありません、誰も私を助けることができますか?

受け入れられた回答

歴史的には、テーブル値のパラメータはdapperではあまり注目されていませんでした。主にSqlConnectionのみで動作するためです(dapperは、 "装飾された" ADO.NETプロバイダを含む任意のプロバイダを対象にしようとします)。つまり、 SqlConnectionがいくつかのラッパーの下に隠れている場所です。あなた 、この機能を追加するために、 IDynamicParameters手動で実装する(または単に既存のDynamicParametersクラスを借用する)ことができます:

void SqlMapper.IDynamicParameters.AddParameters(System.Data.IDbCommand command,
                                                SqlMapper.Identity identity)
{
    ...
    // and then whatever the code is...
    ((SqlCommand)command).Parameters
        .AddWithValue(...,...).SqlDbType = System.Data.SqlDbType.Structured;
    ...
}

また、具体的なDynamicParametersクラスをよりDynamicParameters的なものにするように努力します。将来のビルドでは、単一のメソッドをoverrideし、TVP-ishタイプを検出し、パラメータを手動で追加することができます。



ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ