C# 如何为列创建多值?

C# 如何为列创建多值?,c#,sql-server,insert,C#,Sql Server,Insert,我有两个表TBLCustomers和TBLGroupCustomers。我想在第三个表中插入多值 CREATE TABLE [dbo].[TBLG_Groups] ( [GrId] INT IDENTITY (1, 1) NOT NULL, [CEmail] VARCHAR (250) NOT NULL, [GName] NVARCHAR (70) NOT NULL, [CName] NVARCHAR (450) NULL,

我有两个表
TBLCustomers
TBLGroupCustomers
。我想在第三个表中插入多值

CREATE TABLE [dbo].[TBLG_Groups] 
(
    [GrId]   INT           IDENTITY (1, 1) NOT NULL,
    [CEmail] VARCHAR (250) NOT NULL,
    [GName]  NVARCHAR (70) NOT NULL,
    [CName]  NVARCHAR (450) NULL, 
    PRIMARY KEY CLUSTERED ([GrId] ASC, [CEmail] ASC, [GName] ASC)
)
CEmail
CName
来自
tbl客户
GName
来自
tbl集团客户

为此,我创建了一个存储过程:

CREATE PROC dbo.spG_Groups
    @CEmail VARCHAR(250),
    @GName NVARCHAR (70),
    @CName NVARCHAR(450)
AS
BEGIN
    INSERT INTO TBLG_Groups(CEmail, GName, CName)
    VALUES (@CEmail, @GName, @CName)
END
因为我想显示客户加入组的名称,所以我想表的每条记录都有一个cname和gname

C#代码

SqlCommand cmd1=新的SqlCommand(“spG_组”,康涅狄格州);
cmd1.CommandType=CommandType.StoredProcess;
List YrStrList1=新列表();
foreach(在chGp.Items中列出项目li)
{
如果(li.选定)
{
YrStrList1.相加(li.值);
添加(新的SqlParameter(“@CName”,txtCName.Value));
添加(新的SqlParameter(“@CEmail”,txtemail.Value));
Add(新的SqlParameter(“@GName”,YrStrList1.ToString());
cmd1.ExecuteOnQuery();
}
}

这不起作用,我该怎么办?

foreach
循环之前,您需要定义一次参数,然后在每次迭代中设置它们的值,如下所示:

using (SqlCommand cmd1 = new SqlCommand("spG_Groups", conn))
{
     cmd1.CommandType = CommandType.StoredProcedure;

     // define the parameters *ONCE*
     cmd1.Parameters.Add("@CName", SqlDbType.NVarChar, 450);
     cmd1.Parameters.Add("@CEmail", SqlDbType.VarChar, 250);
     cmd1.Parameters.Add("@GName", SqlDbType.NVarChar, 70);

     List<String> YrStrList1 = new List<string>(); 

     foreach (ListItem li in chGp.Items)
     {
         if (li.Selected)
         {
              YrStrList1.Add(li.Value);

              // just set the *VALUES* of the parameters
              cmd1.Parameters["@CName"].Value = txtCName.Value;
              cmd1.Parameters["@CEmail"].Value = txtemail.Value;
              cmd1.Parameters["@GName"].Value = YrStrList1.ToString();

              cmd1.ExecuteNonQuery();
         }
     }
}
使用(SqlCommand cmd1=新的SqlCommand(“spG_组”,康涅狄格州))
{
cmd1.CommandType=CommandType.StoredProcess;
//定义参数*一次*
cmd1.Parameters.Add(“@CName”,SqlDbType.NVarChar,450);
cmd1.Parameters.Add(“@CEmail”,SqlDbType.VarChar,250);
cmd1.Parameters.Add(“@GName”,SqlDbType.NVarChar,70);
List YrStrList1=新列表();
foreach(在chGp.Items中列出项目li)
{
如果(li.选定)
{
YrStrList1.相加(li.值);
//只需设置参数的*值*
cmd1.Parameters[“@CName”].Value=txtCName.Value;
cmd1.Parameters[“@CEmail”].Value=txtemail.Value;
cmd1.Parameters[“@GName”].Value=YrStrList1.ToString();
cmd1.ExecuteOnQuery();
}
}
}

多值字段是什么意思?您调试代码了吗?该存储过程是否执行过?您得到了什么错误(如果有)??按照您设置代码的方式,第一次执行应该可以工作,但之后,您会继续将参数添加到已经存在的
cmd1
,这样会导致问题。。。。。在
foreach
之前添加一次参数,然后在循环中仅设置参数值-不要反复添加参数@游戏是战争我的意思是我想为这样的字段保存两个值一个
CEmail
have-tow
GName
@marc_s in`cmd1.ExecuteNonQuery()`我看到此错误:过程或函数spG_组指定的参数太多。您从未重置cmd1的参数列表。因此,在foreach循环中添加参数的同时,您可以获得越来越多的参数。这是可行的,但是
GName
的值是:System.Collections.Generic.List`1[System.String]@sadeq:well-这是一个
列表
-当您调用
.ToString()
时,您可以返回类型-这就是它的工作方式。您真正想从字符串列表中得到什么?我想准确地插入
GName
的名称,因为在其他页面中,我应该根据
GName
显示
CName
using (SqlCommand cmd1 = new SqlCommand("spG_Groups", conn))
{
     cmd1.CommandType = CommandType.StoredProcedure;

     // define the parameters *ONCE*
     cmd1.Parameters.Add("@CName", SqlDbType.NVarChar, 450);
     cmd1.Parameters.Add("@CEmail", SqlDbType.VarChar, 250);
     cmd1.Parameters.Add("@GName", SqlDbType.NVarChar, 70);

     List<String> YrStrList1 = new List<string>(); 

     foreach (ListItem li in chGp.Items)
     {
         if (li.Selected)
         {
              YrStrList1.Add(li.Value);

              // just set the *VALUES* of the parameters
              cmd1.Parameters["@CName"].Value = txtCName.Value;
              cmd1.Parameters["@CEmail"].Value = txtemail.Value;
              cmd1.Parameters["@GName"].Value = YrStrList1.ToString();

              cmd1.ExecuteNonQuery();
         }
     }
}