- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在我们的数据库表上,我们使用两个唯一的非聚集索引来创建跨四个字段的唯一约束。我们使用两个,因为其中一个字段 ZipCode
是一个可为空的字段。如果表中存在一条包含 ZipCode
的 null
条目的记录,我们不希望新记录与其他三个字段匹配但具有已定义的 >ZipCode
并被添加(反之亦然)。
问题是使用 SqlBulkCopy
似乎没有强制执行任何约束,因为您可以添加任何您喜欢的记录,而不管表上已有什么。
在另一个程序中,我们使用了 Entity Framework
,因为我们加载的数据量要少得多。使用 EF,这些约束可以完美地工作(它们目前正在生产中)。但是,使用 SqlBulkCopy
时,它们似乎被完全忽略了。
T-SQL
CREATE UNIQUE NONCLUSTERED INDEX [UQ_ChannelStateEndDateZipCodeNOTNULL] ON [dbo].[ZipCodeTerritory]
(
[ChannelCode] ASC,
[StateCode] ASC,
[ZipCode] ASC,
[EndDate] ASC
)
WHERE ([ZipCode] IS NOT NULL)
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, FILLFACTOR = 90) ON [PRIMARY]
GO
CREATE UNIQUE NONCLUSTERED INDEX [UQ_ChannelStateEndDateZipCodeISNULL] ON [dbo].[ZipCodeTerritory]
(
[ChannelCode] ASC,
[StateCode] ASC,
[ZipCode] ASC,
[EndDate] ASC
)
WHERE ([ZipCode] IS NULL)
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, FILLFACTOR = 90) ON [PRIMARY]
GO
C#
Dictionary<DataRow, string> faultyRows = new Dictionary<DataRow, string>();
using (SqlConnection connection = new SqlConnection(connString))
{
//Open Database connection
connection.Open();
//Create transaction objects
SqlTransaction transaction = connection.BeginTransaction();
SqlBulkCopy bulkCopy = new SqlBulkCopy(connection, SqlBulkCopyOptions.CheckConstraints, transaction);
bulkCopy.DestinationTableName = "ZipCodeTerritory";
//Load data and initialize datatable
DataTable dataTable = LoadData(inserts);
IDataReader reader = dataTable.CreateDataReader();
DataTable dataSchema = reader.GetSchemaTable();
DataTable tmpDataTable = InitializeStructure();
//Create array to hold data being transfered into tmpDataTable
object[] values = new object[reader.FieldCount];
while (reader.Read())
{
//Clear temp table for single-record use
tmpDataTable.Rows.Clear();
//Get data for current row
reader.GetValues(values);
//Load values into the temp table
tmpDataTable.LoadDataRow(values, true);
//Load one record at a time
try
{
bulkCopy.WriteToServer(tmpDataTable);
transaction.Commit();
}
catch (Exception ex)
{
faultyRows.Add(tmpDataTable.Rows[0], ex.Message);
}
}
}
编辑
我发现如果定义了 ZipCode
字段,这个约束实际上会被强制执行。 ChannelCode
、StateCode
、ZipCode
、EndDate
字段的任何匹配都将导致 SqlException
具有以下 Message
属性(从我刚刚运行的特定文本中提取):
无法在具有唯一索引“UQ_ChannelStateEndDateZipCodeNOTNULL”的对象“dbo.ZipCodeTerritory”中插入重复键行。重复键值是 (9, WA , 98102 , 9999-12-31)
但是,这是我唯一一次可以触发两个约束之一。
最佳答案
发生这种情况是因为我使用了将数据从模型对象(我仍在某些地方使用 Entity Framework )传输到 DataRow
的方法。下面是我现在使用的方法。在我修复之前,当 null
时,ZipCode
字段被作为空字符串放入 DataRow
列中。由于这在技术上不是空字段,因此未触发约束。
private static DataTable LoadData(List<ZipCodeTerritory>zipCodeList, bool update = false)
{
DataTable dataTable = InitializeStructure();
foreach (var zipcode in zipCodeList)
{
DataRow row = dataTable.NewRow();
try
{
row[0] = zipcode.ChannelCode.Trim();
row[1] = zipcode.DrmTerrDesc.Trim();
row[2] = zipcode.IndDistrnId.Trim();
row[3] = zipcode.StateCode.Trim();
row[4] = (string.IsNullOrWhiteSpace(zipcode.ZipCode) ? null : zipcode.ZipCode.Trim());
row[5] = zipcode.EndDate.Date;
row[6] = zipcode.EffectiveDate.Date;
row[7] = zipcode.LastUpdateId;
row[8] = DateTime.Now.Date;
row[10] = zipcode.ErrorCodes;
row[11] = zipcode.Status;
//Add the Id column if we're doing an update
if(update) row[9] = zipcode.Id;
}
catch (Exception ex)
{
}
dataTable.Rows.Add(row);
}
return dataTable;
}
关于c# - 使用 SqlBulkCopy 时未(始终)强制执行约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21613191/
在 .Net Aspx 页面或 Web 服务需要在表中执行大约 20-200 行插入的情况下,您会推荐以下哪种方法?为什么?小的性能提升可能意味着我仍然会使用我最熟悉的方法,所以请告诉我它是否不会产生
SqlBulkCopy可以创建一个类似于SELECT INTO的表吗? 最佳答案 我认为上述答案不太清楚。 您必须使用SQL创建表。没有别的办法了。而且,如果您只需要创建列结构,那么如果您的源代码位于
在我的程序中,我正在填充数据表,然后将其批量复制到我的数据库中。 但是,如果行中的 3 列匹配,我希望它覆盖数据库中的一行。 例如,如果我有 5 列 成员(member)编号注册日期姓名地址城市状态
我熟悉 C# SqlBulkCopy 类,您可以在其中调用通过 DataTable 传递的“WriteToServer”方法。 我的问题是 SQL Server 中使用什么底层机制来批量插入该数据?
SqlBulkCopy 的建议批量大小是多少?我正在寻找一个可以用作性能调整起点的通用公式。 最佳答案 我有一个导入实用程序与我的 SQL Server 实例位于同一物理服务器上。它使用自定义的 ID
这是 TABLE1 的架构: CREATE TABLE [dbo].[TABLE1] ( [id] [int] IDENTITY(1, 1) NOT NULL, [code] [int
要将数据从一个数据库复制到具有相同架构的不同服务器中的另一个数据库,我计划使用 C sharp 库中的 SqlBulkCopy 类。 SqlBulkCopy 在插入记录时是否会保持与数据表中相同的顺序
我可以忽略我传递给 SqlBulkCopy 的数据表中已存在于 sql 数据库中的数据的重复记录吗?如果是,那么如何,如果否和其他选项,还要解释我。 最佳答案 不,这不是内置的。您需要先清理客户端上的
我正在执行从 excel 电子表格到临时表的数据的 sql 批量复制,然后从临时表到生产数据库。 我的问题是,如果由于任何原因上传到临时表或生产数据库失败,事务是否回滚并且没有数据被导入或修改现有数据
我的软件可以部署在两种不同的配置中:一种是我全天偶尔收到单个数据点的涓流馈送,另一种是我在一天结束时得到所有数据的转储。对于日终转储,显然,我将使用具有可配置批处理大小的 SqlBulkCopy()
在我的网络应用程序中,用户可以一次插入大量数据,以提高性能,我正在使用 SqlBulkCopy 类。对于插入两个不同表的单个操作,它会运行多次。如果用户取消操作或操作失败,那么我需要回滚数据,因此我使
我有以下代码..它实际上使用 SQLBulkCopy 将数据插入目标。由于死锁,此代码在源 SQL 服务器中经常失败。仅供引用,正在复制的表可以在我们执行批量复制时使用(我的意思是一些插入/选择将运行
我正在尝试使用 SqlBulkCopy 通过在我的应用程序中手动填充 DataTable 来将新行插入到我的数据库表中。 这适用于所有表除了具有由 3 列组成的复合主键的表。每当我尝试将任何内容 Sq
我正在使用 SqlBulkCopy 将一批记录从 MySQL 复制到 SQL Server。 正好 30 秒后,我明白了 System.Data.SqlClient.SqlException (0x8
这是我的场景:我必须在表中导入大文件,所以我使用了 sqlBulkCopy,因为其他方法太慢了。 这是一个文件行的例子: String1|String2|String3|String4 这是表结构:
有人可以帮我解决这个错误吗?这是我的代码: using System; using System.Drawing; using System.Collections; using System.Com
我正在努力将数据库从 MS Access 迁移到 sql server。为了将数据移动到新表中,我决定编写一个同步例程,因为模式已经发生了相当大的变化,它让我可以在运行它的程序上运行测试,并在我需要新
我正在使用 SqlBulkCopy 对象将生成的几百万行插入到数据库中。唯一的问题是我要插入的表有一个标识列。我尝试将 SqlBulkCopyOptions 设置为 SqlBulkCopyOption
从 csv 文件插入数据。如何使用存储过程而不是 SqlBulkCopy 从数据表插入到数据库?当前使用: using (SqlBulkCopy sqlBulkCopy = new SqlBulkC
我正在尝试找到一种使用 SqlBulkCopy 向 MSSQLServer 表执行批量插入的方法,该方法将在出现错误时继续,并返回无法插入的任何行的数据表。 当我尝试使用 SqlBulkCopy 时,
我是一名优秀的程序员,十分优秀!