gpt4 book ai didi

c# - Dapper 存储过程的表值参数

转载 作者:行者123 更新时间:2023-11-30 15:34:33 25 4
gpt4 key购买 nike

我正在尝试调用一个接受表值参数的存储过程。

我正在遵循 this 上的指南问题,实现自定义参数类型:

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 类在这里更具多态性,以便在未来的构建中您可以覆盖单个方法,检测 TVP-ish类型,然后手动添加参数。

关于c# - Dapper 存储过程的表值参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16042499/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com