C# 使用SqlCommand,如何向其对象添加多个参数,通过winform在sql表中插入

C# 使用SqlCommand,如何向其对象添加多个参数,通过winform在sql表中插入,c#,.net,sql,sql-server-2005,sqlcommand,C#,.net,Sql,Sql Server 2005,Sqlcommand,我的winform中有10个文本框,我需要将这些文本框中键入的文本保存到sql数据库表的10列中。为此,我要写: INSERT INTO item (c1,c2,c3...,c10) values (@a,@b....@j) cmd.Parameters.Add("@a",SqlDbType.Varchar) cmd.Parameteres["@a"].Value=textbox1.Text; cmd.Parameters.Add("@b",SqlDbType.Varchar) cmd.P

我的winform中有10个文本框,我需要将这些文本框中键入的文本保存到sql数据库表的10列中。为此,我要写:

INSERT INTO item (c1,c2,c3...,c10) values (@a,@b....@j) 

cmd.Parameters.Add("@a",SqlDbType.Varchar)
cmd.Parameteres["@a"].Value=textbox1.Text;

cmd.Parameters.Add("@b",SqlDbType.Varchar)
cmd.Parameteres["@b"].Value=textbox2.Text;.
.
.
.
.
cmd.Parameters.Add("@j",SqlDbType.Varchar)
cmd.Parameteres["@j"].Value=textbox10.Text;
或对每个文本框分别进行十次查询:

INSERT INTO item (c1) values (@a)
cmd.Parameters.Add("@a",SqlDbType.Varchar)
cmd.Parameteres["@a"].Value=textbox1.Text;

INSERT INTO item (c2) values (@b) 
cmd.Parameters.Add("@b",SqlDbType.Varchar)
cmd.Parameteres["@b"].Value=textbox2.Text;.
.
.
INSERT INTO item (c10) values (@j)
cmd.Parameters.Add("@j",SqlDbType.Varchar)
cmd.Parameteres["@j"].Value=textbox10.Text;
或者,请建议一个有效的代码


如何在一条语句中向cmd添加多个参数?可能吗?

您可以使用扩展方法,如下所示:

public static class DbCommandExtensions
{
    public static void AddInputParameters<T>(this IDbCommand cmd,
        T parameters) where T : class
    {
        foreach (var prop in parameters.GetType().GetProperties())
        {
            object val = prop.GetValue(parameters, null);
            var p = cmd.CreateParameter();
            p.ParameterName = prop.Name;
            p.Value = val ?? DBNull.Value;
            cmd.Parameters.Add(p);
        }
    }
}
cmd.AddInputParameters(new { a = textBox1.Text, b = TextBox2.Text, /* etc */ });
void AddParams(DBCommand cmd,params object[] parameters)
{
    if (parameters != null)
    {
        int index = 0;
        while (index < parameters.Length)
        {
            cmd.Parameters.AddWithValue("@"+(string)parameters[index], parameters[index + 1]);
            index += 2;
        }
    }
}

我已经在一些项目中使用过,没有问题。

您可以使用扩展方法,如下所示:

public static class DbCommandExtensions
{
    public static void AddInputParameters<T>(this IDbCommand cmd,
        T parameters) where T : class
    {
        foreach (var prop in parameters.GetType().GetProperties())
        {
            object val = prop.GetValue(parameters, null);
            var p = cmd.CreateParameter();
            p.ParameterName = prop.Name;
            p.Value = val ?? DBNull.Value;
            cmd.Parameters.Add(p);
        }
    }
}
cmd.AddInputParameters(new { a = textBox1.Text, b = TextBox2.Text, /* etc */ });
void AddParams(DBCommand cmd,params object[] parameters)
{
    if (parameters != null)
    {
        int index = 0;
        while (index < parameters.Length)
        {
            cmd.Parameters.AddWithValue("@"+(string)parameters[index], parameters[index + 1]);
            index += 2;
        }
    }
}
我已经在一些项目中使用了这个方法,没有任何问题。

我认为您可以使用这个方法

我想你可以用这个方法


您可以使用如下函数:

public static class DbCommandExtensions
{
    public static void AddInputParameters<T>(this IDbCommand cmd,
        T parameters) where T : class
    {
        foreach (var prop in parameters.GetType().GetProperties())
        {
            object val = prop.GetValue(parameters, null);
            var p = cmd.CreateParameter();
            p.ParameterName = prop.Name;
            p.Value = val ?? DBNull.Value;
            cmd.Parameters.Add(p);
        }
    }
}
cmd.AddInputParameters(new { a = textBox1.Text, b = TextBox2.Text, /* etc */ });
void AddParams(DBCommand cmd,params object[] parameters)
{
    if (parameters != null)
    {
        int index = 0;
        while (index < parameters.Length)
        {
            cmd.Parameters.AddWithValue("@"+(string)parameters[index], parameters[index + 1]);
            index += 2;
        }
    }
}

或者您可以使用@Matt Hamilton建议的扩展在DBCommand类中添加此函数。

您可以使用以下函数:

public static class DbCommandExtensions
{
    public static void AddInputParameters<T>(this IDbCommand cmd,
        T parameters) where T : class
    {
        foreach (var prop in parameters.GetType().GetProperties())
        {
            object val = prop.GetValue(parameters, null);
            var p = cmd.CreateParameter();
            p.ParameterName = prop.Name;
            p.Value = val ?? DBNull.Value;
            cmd.Parameters.Add(p);
        }
    }
}
cmd.AddInputParameters(new { a = textBox1.Text, b = TextBox2.Text, /* etc */ });
void AddParams(DBCommand cmd,params object[] parameters)
{
    if (parameters != null)
    {
        int index = 0;
        while (index < parameters.Length)
        {
            cmd.Parameters.AddWithValue("@"+(string)parameters[index], parameters[index + 1]);
            index += 2;
        }
    }
}

或者您可以使用@Matt Hamilton建议的扩展在DBCommand类中添加此函数。

您在问题中建议的两个“解决方案”在语义上是不同的。 您应该使用哪一种,取决于您的表格布局

第一个解决方案在表中插入一条记录,第二个insert语句为每个值文本框插入一条记录行


这里很难给出一个好的答案,因为我们不知道您将在该表中保存什么,因此,我们不能说您应该如何保存它。如何保存它,本质上取决于您调用SQL insert语句的方式。

您在问题中建议的两个“解决方案”在语义上是不同的。 您应该使用哪一种,取决于您的表格布局

第一个解决方案在表中插入一条记录,第二个insert语句为每个值文本框插入一条记录行


这里很难给出一个好的答案,因为我们不知道您将在该表中保存什么,因此,我们不能说您应该如何保存它。如何保存它,本质上取决于您调用SQL insert语句的方式。

先生,我使用的是.net 2.0,因此,在“var”的位置,我应该使用什么呢?IDbCommand.CreateParameter返回一个IDbDataParameter,所以声明p为该值。否则,据我所知,这在.NET 2.0中应该可以正常工作。先生,我正在使用.NET 2.0,因此在使用'var'时,我应该使用什么?IDbCommand.CreateParameter返回一个IDbDataParameter,因此声明p为该参数。否则,据我所知,这在.NET2.0中应该可以正常工作。