我们的表中有几列不是用户友好的名称,所以我们在实际的GUI中更改它们。
例如,数据库中的列标记为“IntAmt”,但用户没有线索,因此在程序中我们将此列称为“兴趣金额”。
问题是如果我使用如下所示的直接列映射,那么它将会出错,因为这些列不匹配。数据库中没有名为“InterestAmount”的列
那么有没有一种方法可以在带注释或其他东西的映射中引用正确的列名?我们也在使用Entity Framework。
var connection = DbContext.Database.Connection.ConnectionString;
using (SqlConnection sqc = new SqlConnection(connection))
{
sqc.Open();
using (SqlBulkCopy bcp = new SqlBulkCopy(sqc))
{
bcp.DestinationTableName = strTargetTable;
sourceData.Columns.Cast<DataColumn>().ToList().ForEach(x =>
bcp.ColumnMappings
.Add(new SqlBulkCopyColumnMapping(x.ColumnName, x.ColumnName)));
bcp.BatchSize = 50000;
bcp.BulkCopyTimeout = 12000;
bcp.WriteToServer(sourceData);
}
sqc.Close();
}
经过进一步调查后,我们将列映射存储在表中,因此表格如下所示
TableName: ColumnMappingTable
[ColumnName] [GuiColumnName]
IntAmt InterestAmount
PrinAmt PrincipalAmount
所以说有一种方法可以动态映射这种方式吗?我们有很多表和硬编码映射代码中的每个名称将花费大量时间
在定义db对象的类和类型为SqlBulkCopyColumnMapping的IEnumerable中
public static IEnumerable<SqlBulkCopyColumnMapping> GetObjectNameColumnMappings()
{
return new[]
{
new SqlBulkCopyColumnMapping(nameof(propertyName), "dbColumnName"),
new SqlBulkCopyColumnMapping(nameof(propertyName2), "dbColumnName2")
};
}
然后调用此方法并将其设置为等于列映射
using (SqlBulkCopy bcp = new SqlBulkCopy(sqc))
{
bcp.DestinationTableName = strTargetTable;
bcp.ColumnMappings = classInstance.GetObjectNameColumnMappings();
bcp.BatchSize = 50000;
bcp.BulkCopyTimeout = 12000;
bcp.WriteToServer(sourceData);
}
尝试使用TableMappings.Add()
Article供参考: