N 個のデータテーブルがあり、N-1 個のデータテーブルがいくつかのエンティティを表し、1 個がこれらのエンティティ間の関係を表しています。
Entity Countryのように
Country DATATABLE
ID | Country Name | Country Code
------------------------------------
ID1 | USA | USA
ID2 | INDIA | IND
ID3 | CHINA | CHI
実体大陸
Continent DATATABLE
ID | Continent Name | Continent Code
------------------------------------
IDC1 | NORTH AMERICA | NA
IDC2 | SOUTH AMERICA | SA
IDC3 | ASIA | AS
実体会社
Company DATATABLE
ID | Company Name | Company Code
------------------------------------
CM1 | XYZ Company | XYZ
CM2 | Fun Company | Fun
CM3 | ABC Company | ABC
これらの関係。
Company_Country_Continent_Relationship DataTable
ID | Company | Country | Continent | Some Value1 | Some Value 2
-------------------------------------------------------------------------------------
R1 | CM1 | ID1 | IDC1 | 100 | 150
R2 | CM2 | ID2 | IDC3 | 200 | 200
R3 | CM3 | ID1 | IDC1 | 150 | 250
R4 | CM1 | ID3 | IDC3 | 100 | 150
R5 | CM2 | ID1 | IDC1 | 200 | 200
R6 | CM3 | ID2 | IDC3 | 150 | 250
R7 | CM1 | ID2 | IDC3 | 100 | 150
R8 | CM2 | ID3 | IDC3 | 200 | 200
R9 | CM3 | ID3 | IDC3 | 150 | 250
ここで、ID の代わりに名前を保持する別の関係テーブルを生成する必要があります。この例では、関係データは会社、国、および大陸の ID を格納しています。これらの ID 値を名前に変換したいと思います。代わりに、または CM1 - XYZ 会社。
この変換では、メソッドを使用してTramnsformRelationshipData
いますが、正しく機能しています。
public static DataTable TramnsformRelationshipData(DataTable relationshipData, Dictionary<string, DataTable> mapping)
{
DataTable transformedDataTable = null;
if (relationshipData == null || mapping == null )
return null;
transformedDataTable = relationshipData.Copy();
foreach (DataColumn item in relationshipData.Columns)
{
if (mapping.ContainsKey(item.ColumnName))
{
var instanceData = mapping[item.ColumnName];
if (instanceData == null)
return null;
foreach (DataRow row in transformedDataTable.Rows)
{
var filteredRows = instanceData.Select("ID = '" + row[item.ColumnName] + "'");
if (filteredRows.Any())
row[item.ColumnName] = filteredRows[0][1];
}
}
}
return transformedDataTable;
}
ただし、このメソッドはすべてのデータテーブルを反復し、リレーションシップデータに変換するエンティティがさらにある場合は非常に遅くなります。したがって、このコードを最適化して、多数の行を持つ多数のデータテーブルを操作するにはどうすればよいですか。
編集済み : ほとんどの場合、これらのデータは DB に保存されません。これらはメモリ内にあり、メモリ内ではこれらのデータテーブルの数を増減できます。
ありがとう。