gpt4 book ai didi

c# - 将列表作为 SQL 表类型参数传递

转载 作者:太空狗 更新时间:2023-10-29 21:22:25 28 4
gpt4 key购买 nike

我正在尝试将类(class)列表作为 DbParameter 传递. 表类型 可能是在我的存储过程中定义的。

现在,我不知道如何通过 List<>进入存储过程,因为定义了接受 Tables 的表类型仅。

在这里,我把我的方法。

public static AddCustomer(List<Customer> customer)
{
List<DbParameter> lstDbParameters = null;

try
{
#region Set the Parameters
lstDbParameters = new List<DbParameter>();
SqlParameter dbAcceptedBillDetails = new SqlParameter("@Customers",
customer);

dbAcceptedBillDetails.SqlDbType = SqlDbType.Structured;
lstDbParameters.Add(dbAcceptedBillDetails as DbParameter);
lstDbParameters.Add(CDDAC.MakeDbParameter(dbProvider,
"@ErrorMessage",
DbType.String,
null,
500,
ParameterDirection.Output));
#endregion

//Call the static ExecuteNonQuery method.
CDDAC.ExecuteNonQuery(dbProvider,
connectionString,
"AddCustomer",
CommandType.StoredProcedure,
lstDbParameters.ToArray());
}
catch (Exception ex)
{
throw;
}
}

我遇到这样的错误:

Failed to convert parameter value from a List1 to a IEnumerable1.

我知道我可以将此列表转换为 DataTable然后在存储过程中传递它,但它似乎很耗时。 :(

最佳答案

最后,我自己得到了答案。但是在查找过程中,我发现无法转换 List<>IEnumerable<>直接地。

但是这篇文章对于通过object交易数据非常有用或 List<Obj>

http://www.c-sharpcorner.com/UploadFile/pchandraker/passing-table-valued-parameter-to-stored-procedu-part-2/

很有用。 :)

关于c# - 将列表作为 SQL 表类型参数传递,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24061793/

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