【问题标题】:How to create dynamic parameters in SQL Server stored procedure如何在 SQL Server 存储过程中创建动态参数
【发布时间】:2015-02-07 12:15:28
【问题描述】:

我有一个动态生成输入的表单,然后我获取它们的值并动态生成命令参数。

    SqlConnection con = new SqlConnection(cs);

    SqlCommand cmd =new SqlCommand("insert_op",con);
    cmd.CommandType = CommandType.StoredProcedure;

    for (int i = 0; i < Request.Form.Count; i++)
    {
        if (Request.Form["frm_option" + (i + 1)] != null)
        {

            cmd.Parameters.AddWithValue("@op" + i, Request.Form["frm_option" + (i + 1)]);
        }
    }
    try
    {
        using (con)
        {
            con.Open();
            cmd.ExecuteNonQuery();
        }
    }
    catch
    {
    }

如何将这些动态参数传递给 SQL Server 存储过程,存储过程应该如何?

【问题讨论】:

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


    【解决方案1】:

    首先,这不是正确的设计。

    要实现您的目标,您需要在 SQL 语句中传递多个值,如下所示

    SQL

    INSERT INTO tbl_options(op_name) VALUES (value1),(value2),...(nthValue)
    

    代码

    你的代码会是这样的

    string command = "INSERT INTO tbl_options(op_name) VALUES";    
    for (int i = 0; i < Request.Form.Count; i++)
                    {                      
                        if (Request.Form["frm_option" + (i + 1)] != null)
                        {
                            command += "(@op" + i + "),";
    
                            cmd.Parameters.AddWithValue("@op" + i, Request.Form["frm_option" + (i + 1)]);
                        }
                    }
    

    【讨论】:

    • 存储过程应该怎么做?
    • 我建议将单个参数传递给 SP,它应该是 csv list 。 (我假设所有值都将转到表的单列)。
    • 但我想将每个参数插入单独的行。
    • 是的,您会将 csv 列表传递给存储过程,然后迭代该列表以将其插入到表中。
    【解决方案2】:

    如果您想“将每个参数插入单独的行”,那么使用表变量作为存储过程参数可能会更好?

    您的用户定义表类型和存储过程可能如下所示:

    create type dbo.ValueTableType as table (Value varchar(255))
    GO
    
    create procedure dbo.InsertValues
        @Values dbo.ValueTableType readonly
    as
    begin
    
        insert into dbo.YourTable (Value)
        select Value from @Values;
    end
    

    请参阅此 ADO.NET 示例,了解如何初始化表参数并将其传递给存储过程 https://stackoverflow.com/a/10409710/623190

    【讨论】:

      【解决方案3】:

      您可以为表中的每个字段提供默认值,因此您未传入的任何参数都将获得默认值。这里我演示了 NULL 的默认值。

      CREATE PROCEDURE [dbo].[sproc_tbl_options_Insert] 
          @op_name nvarchar(50) = NULL,
          @op_somethingelse nvarchar(5) = NULL,
          @op_number int = NULL
      AS
      BEGIN
          INSERT INTO [tbl_options] (op_name, op_somethingelse, op_number)
          VALUES (@op_name, @op_somethingelse, @op_number);
      END
      

      【讨论】:

        猜你喜欢
        • 2015-04-24
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2012-05-01
        • 2013-07-18
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多