gpt4 book ai didi

c# - 使用数据行列表来存储数据

转载 作者:太空宇宙 更新时间:2023-11-03 14:27:24 26 4
gpt4 key购买 nike

我在 2 个类之间有主从关系。大师类将包含许多细节的列表。目前我正在使用

public class Master: cloneable<T>
{
//other properties here...
private List<detailClass> details
public List<detailClass> Details
{
get { return details; }
}
}

在大师类里。在保存此类时,我需要在将详细信息列表传递到 sp 之前使用数据表。 (因为我们在 sql2008 中使用表值参数)。使用 tvp 的原因是 1 个 master 可以包含超过 10k 的详细信息,而 tvp 是一种非常有效的方式,可以非常快速地将所有这些信息转储到数据库中。

问题:当我将列表转换为数据表以进行数据库插入时,相同数据的内存使用量增加了一倍。除了直接使用数据表之外,是否有更好的方法将详细信息保存在 master 中?

问题:我的下一个选择是尝试使用列表详细信息,并执行 datatable.ImportRow(row)。但我不知道如何在不定义任何列的情况下将数据添加到一行中。我也不知道任何外部对象如何访问此类列表中的各个详细信息字段。


正在关注 casperOne's answer我用了 IEnumerable<SqldataRecord>方法,并且能够通过流式传输插入数据,而无需在内存中创建额外的数据表。为了帮助其他寻找类似解决方案的人,我在下面发布了代码。

public class DetailCollection: List<Detail>, IEnumerable<SqlDataRecord>
{
IEnumerator<SqlDataRecord> IEnumerable<SqlDataRecord>.GetEnumerator()
{
// mapping the properties of the Detail object to the
// user defined table type in sql
SqlMetaData[] metaDataArray = new SqlMetaData[4];

//-1 indicates varchar(max) sql data type
metaDataArray[0] = new SqlMetaData("Col1", SqlDbType.VarChar, -1);
metaDataArray[1] = new SqlMetaData("Col2", SqlDbType.TinyInt);
metaDataArray[2] = new SqlMetaData("Col3", SqlDbType.VarChar,100);
metaDataArray[3] = new SqlMetaData("Col4", SqlDbType.Int);

SqlDataRecord sdr = new SqlDataRecord(metaDataArray);


foreach (Detail detailRecord in this)
{
sdr.SetValue(0, detailRecord.Property1);
sdr.SetValue(1, Convert.ToByte(detailRecord.Property2));
sdr.SetValue(2, detailRecord.Property3);
sdr.SetValue(3, detailRecord.Property4);
yield return sdr;
}
}
}

最佳答案

您可以将结果流式传输到 table-valued parameter使用以下两种方法之一:

  • IEnumerable<SqlDataRecord> - 您可以使用 yield returnIEnumerable<SqlDataRecord>实现(或 LINQ,这更容易)来创建流解决方案。
  • DbDataReader 实现 - 您可以创建一个实现,该实现将引用您的列表并在读者被枚举时提供适当的转换。

使用其中任何一个,您基本上可以创建将从列表中获取项目的实现,然后将结果转换为流式传输为表值参数。这样,您不必在应用程序中重新实现第二个列表,您可以根据需要对第一个列表执行转换。

有关详细信息,请参阅 MSDN 中标题为“Table-Valued Parameters in SQL Server 2008”的部分,特别是“配置 SqlParameter 示例”和“使用 DataReader 流式处理行”部分。

关于c# - 使用数据行列表来存储数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3548764/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com