クエリがあります-" SELECT PK1 FROM users
";
また、myTable
int型の3つのフィールドで名前が付けられたデータテーブルがあります。
-----------
| myTable |
-----------
| field1 |
| field2 |
| field3 |
-----------
myTable
クエリから返された各行について、フィールド1とフィールド3をnullのままにして、PK1値をフィールド2に入れたいと思います。
これまでに試したサンプルコードをいくつか示しますが、機能していないようです。myTable
代わりに、フィールドPK1が新しいフィールドとして末尾に追加されます。
class Program
{
static void Main(string[] args)
{
string SQL = "SELECT PK1 FROM users";
SqlConnection connection = new SqlConnection([my connection string]);
DataTable myTable = new DataTable();
SqlDataAdapter adapter = new SqlDataAdapter();
adapter.SelectCommand = new SqlCommand(SQL, connection);
myTable.Columns.Add("field1", typeof(Int32));
myTable.Columns.Add("field2", typeof(Int32));
myTable.Columns.Add("field3", typeof(Int32));
DataTableMapping dataMapping = adapter.TableMappings.Add("myTable", "users");
dataMapping.ColumnMappings.Add("PK1", "field2");
adapter.Fill(myTable);
foreach (DataRow row in myTable.Rows)
{
Console.WriteLine("------------");
foreach (DataColumn column in myTable.Columns)
{
Console.WriteLine(column.ColumnName + " : " + row[column]);
}
}
Console.ReadKey();
}
}
コードに問題がありますか、それともフィールドをマッピングする別の方法がありますか?
これは、この質問の目的のための簡略化された例です。このようなフィールド名のマッピングは、特定の位置に値を挿入するよりも理想的です。