尝试在表中插入或更新多行时获取异常

时间:2013-08-12 05:51:24

标签: c# sql-server-2008

我正在尝试将Datatable中的多行插入并更新到数据库表中。 下面是将Datatable传递给存储过程的代码:

 DataTable dtUserRights = new DataTable();
        PropertyInfo[] piT = typeof(clsRightsAL).GetProperties(); //Gets all column values with there datatype
        foreach (PropertyInfo pi in piT)
        {
              //create a datacolumn for each property
              DataColumn dc = new DataColumn(pi.Name, pi.PropertyType);
              dtUserRights.Columns.Add(dc);

        }

        try
        {
            if (con.State == ConnectionState.Closed)
            {
                con.Open();
            }
            for (int item = 0; item < objUserRightsALLst.Count; item++)
            {
                DataRow dr = dtUserRights.NewRow();


                for (int property = 0; property < dtUserRights.Columns.Count; property++)
                {
                    dr[property] = piT[property].GetValue(objUserRightsALLst[item], null);
                }

                dtUserRights.Rows.Add(dr);
            }
            objCmd = new SqlCommand();
            objCmd.CommandText = "sp_AD_InsertUpdateGroupRights";
            objCmd.CommandType = CommandType.StoredProcedure;
            objCmd.Connection = con;
            objCmd.Parameters.Clear();
            SqlParameter tableParameter =  objCmd.Parameters.AddWithValue("@GroupRightslist", dtUserRights);
            tableParameter.SqlDbType = SqlDbType.Structured;
 intCount = objCmd.ExecuteNonQuery();

            if (con.State == ConnectionState.Open)
            {
                con.Close();
            }
        }
        catch (Exception e)
        {
            throw e;
        }

以下是我正在呼叫的SP:

CREATE PROCEDURE [dbo].[sp_AD_InsertUpdateGroupRights]  
@GroupRightslist as  [dbo].[GroupRightsList] ReadOnly  
AS  
BEGIN   
if Not Exists(Select intID from tblADGroupRights where intID = (Select l.intID from @GroupRightslist l))  
Begin  
  insert into tblADGroupRights(IntGroupID,intMenuID,blAdd,blEdit,blView,blGrant,blStatus,strUserCreated
) Select l.IntGroupID,l.intMenuID,l.blAdd,l.blEdit,l.blView,l.blGrant,l.blStatus,
l.strBy from GroupRightslist l   

End     
 else    

  begin  
update A set blAdd = l.blAdd,blEdit = l.blEdit,blView = l.blView,blGrant = l.blGrant   
 FROM  tblADGroupRights A INNER JOIN @GroupRightslist l on A.intID = l.intID  
where A.intID = l.intID     
end
END

当我将单行传递到存储过程时,数据将被插入,但是当数据表有多个记录时,我得到了异常:

  

子查询返回的值超过1。当子查询遵循=,!=,&lt;,&lt; =,&gt;,&gt; =或子查询用作表达式时,不允许这样做。

我的更新查询根本不起作用。

我的用户定义表类型:

CREATE TYPE [dbo].[GroupRightsList] AS TABLE(
[intID] [int] NULL,
[intProfileID] [int] NULL,
[IntGroupID] [int] NULL,
[intMenuID] [int] NULL,
[blAdd] [bit] NULL,
[blEdit] [bit] NULL,
[blView] [bit] NULL,
[blGrant] [bit] NULL,
[blStatus] [bit] NULL,
[strBy] [nvarchar](max) NULL
) 

我知道当Select查询返回超过1的值并且我们没有正确处理它时,这个异常通常会引发,但在我的场景中,因为我正在使用用户类型表我已经看到很多站点,他们已经在就像我一样。

1 个答案:

答案 0 :(得分:1)

  

子查询返回的值超过1。当子查询遵循=,!=,&lt;,&lt; =,&gt;,&gt; =或子查询用作表达式时,不允许这样做。

纯粹是sp错误。这意味着在你的sp中你有一个子查询返回多个不允许的记录。最可能的是下面的行

Select intID from tblADGroupRights where intID = (Select l.intID from @GroupRightslist l)

将其更改为

Select intID from tblADGroupRights where intID = (Select Top 1 l.intID from @GroupRightslist l)

Select intID from tblADGroupRights where intID in (Select l.intID from @GroupRightslist l)