Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# SqlBulkCopy使用复合主键复制到表中_C#_.net_Sql_Sql Server 2005_Sqlbulkcopy - Fatal编程技术网

C# SqlBulkCopy使用复合主键复制到表中

C# SqlBulkCopy使用复合主键复制到表中,c#,.net,sql,sql-server-2005,sqlbulkcopy,C#,.net,Sql,Sql Server 2005,Sqlbulkcopy,我试图使用SqlBulkCopy在我的应用程序中手动填充一个数据表w/来将新行插入到我的DB表中 这适用于所有表,但具有由3列组成的复合主键的表除外。每当我尝试将任何内容复制到此表中时,都会出现以下错误: Violation of PRIMARY KEY constraint 'PK_MYCOMPOSITEKEY'. Cannot insert duplicate key in object 'dbo.MyTable'. The statement has been terminated. 这

我试图使用SqlBulkCopy在我的应用程序中手动填充一个数据表w/来将新行插入到我的DB表中

这适用于所有表,但具有由3列组成的复合主键的表除外。每当我尝试将任何内容复制到此表中时,都会出现以下错误:

Violation of PRIMARY KEY constraint 'PK_MYCOMPOSITEKEY'. Cannot insert duplicate key in object 'dbo.MyTable'.
The statement has been terminated.
这可能吗

我已尝试使用以下方法设置数据表的主键:

dt.PrimaryKey = new[] {dt.Columns["PKcolumn1"], dt.Columns["PKcolumn2"], dt.Columns["PKcolumn3"]};

但同样,运气不好。

您遇到的问题是数据

在输入文件中,有以下两个或其中一个

e pk列中数据与表中数据相同的行


该文件至少有两行具有相同pk列值,并批量插入到暂存表中。清除所有重复记录。然后使用直接SQL进行插入。编写插入代码时,请确保将其限制为暂存表中不在prod表中的记录。

在访问DB之前,您应该验证批量数据的副本,问题也可能存在(不仅仅是与现有约束冲突,或者DB中的记录冲突)。它确实有效,报告它通常是正确的


尽管如此,整个DataSet甚至DataReader的展示在映射、糟糕的无类型设计、大量不必要的转换、分配、基于对象[]的值等方面都是一个混乱的练习,整个过程变成了顺序、类型和字符串相关的混乱(只有MS才能设计并继续设计)。另一方面,本地OLEDB批量接口更干净。

我也这么认为。但是,我已将插入限制为一行我知道尚未在数据库表中的值。数据库认为它们是-值是什么?您和Majkara是正确的。我使用的是Linq to SQL,在DB.SubmitChanges()过程中,外键依赖项被遍历,它将这些外键行插入到我的执行路径中的SqlBulkCopy之前……尽管我没有显式地添加这些行本身。