ふと思ったんですが、CSVファイル同士でのSQL的な結合が可能であれば、ファイル連携するようなバッチシステムを組む場合、DBサーバの負荷を下げたシステムを組めるのでは?と思いちょっとやってみました。
やってみたところ、あっさりできてしまいました。コードはこんな感じ。
private void button1_Click(object sender, EventArgs e)
{
string csvDir = @"d:\temp";
string csvFileName = "Text1.csv";
string csvFileName2 = "Text2.csv";
OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder();
builder["Driver"] = "Microsoft Text Driver (*.txt; *.csv)";
builder["dbq"] = csvDir;
builder["Extension"] = "text;HDR=No;FMT=Delimited\"";
System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch();
sw.Start();
using (OdbcConnection con = new OdbcConnection(builder.ConnectionString))
{
con.Open();
string strSQL = "SELECT T1.* FROM (" + csvFileName + " T1 INNER JOIN " + csvFileName2 + " T2 ON T1.F1=T2.F1)";
using (OdbcCommand cmd = new OdbcCommand(strSQL, con))
using (OdbcDataReader rd = cmd.ExecuteReader())
{
StringBuilder sb = new StringBuilder();
for (int col = 0; col < rd.FieldCount; col++)
{
sb.Append(rd.GetName(col)).Append(",");
}
sb.Remove(sb.Length - 1, 1);
System.Diagnostics.Debug.WriteLine(sb);
while (rd.Read())
{
sb.Length = 0;
for (int col = 0; col < rd.FieldCount; col++)
{
sb.Append(rd.GetValue(col)).Append(",");
}
sb.Remove(sb.Length - 1, 1);
System.Diagnostics.Debug.WriteLine(sb);
}
}
}
sw.Stop();
label1.Text = String.Format("完了{0:#,##0}ms", sw.ElapsedMilliseconds);
}