存储过程使用数组参数csharp到mssql

时间:2017-06-21 17:28:27

标签: c# arrays sql-server asp.net-mvc stored-procedures

这是我在SQL中的手动查询工作:

SELECT * FROM Accounts where Phone in ('05763671278','05763271578','04763125578') 

如何从csharp获取存储过程的参数?

我在C#中有一个手机阵列。我从视图中的参数中获取此数组(多选复选框)。这是我的观点:

<td><input type="checkbox" class="CheckboxClass" value="'@item.Phones'"/></td>

这是我的控制器动作:

public ActionResult SendSMSOrMail(string[] values){

    // this give "'05763671278','05763271578','04763125578'"
    string numbers = string.Join(",", values);
    // ...
    utility.cmd.Parameters.Add("@numbers", numbers);
    // ...
}

但结果是null。怎么了?我想获得包含这些手机的所有记录的结果。

2 个答案:

答案 0 :(得分:1)

我建议您使用table valued parameter

CREATE TYPE PhonesTableType AS TABLE   
( 
    Phone VARCHAR(12)
)
GO  

然后,您应声明(在创建脚本中)存储过程需要此类型的参数:

CREATE PROCEDURE dbo.your_stored_procedure_name
(
    @PhonesTableType PhonesTableType READONLY
) 
....
SELECT A.* 
FROM Accounts AS A
INNER JOIN @PhonesTableType AS P
ON  A.Phone = P.Phone

然后在C#代码中,你应该创建一个包含一列的DataTable,然后传递你提到的值。最后,您应该将此参数传递给存储过程。

var phonesDataTable = new DataTable("Phones");
phonesDataTable.Columns.Add("Phone", typeof(string));
foreach(var phone in phones) // phones is the values
{
    phonesDataTable.Rows.Add(phone);
}

然后,如果我们假设您已将command命名为要执行的命令,则在执行之前,您应将上述内容添加为参数:

var sqlParameter = new SqlParameter
{
    ParameterName = "@PhonesTableType",
    SqlDbType = SqlDbType.Structured,
    Value = phonesDataTable
}; 
command.Parameters.Add(sqlParameter);

答案 1 :(得分:1)

有几种方法可以做到这一点。第一种是将数组创建为一个文本字符串,用逗号或分号或其他分隔符分隔,然后在SQL中解析该字符串。这非常简单直接,但不能很好地扩展,并且参数的最大字符长度有限制。

第二种选择是使用XML参数。示例:

https://stackoverflow.com/a/1069388/61164

第三种选择是使用Table参数,该参数作为.NET集合传递。

我没有那个方便的例子。我以前做过,但这应该给你足够的信息来搜索自己。