我有一个查询——“ SELECT PK1 FROM users
”;
我还有一个名为myTable
int 类型的三个字段的数据表;
-----------
| myTable |
-----------
| field1 |
| field2 |
| field3 |
-----------
对于从我的查询返回的每一行,我想将 PK1 值放入 field2 中,myTable
使 field1 和 field3 为空。
这是我到目前为止尝试过的一些示例代码,但它似乎不起作用。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();
}
}
我的代码中是否存在问题,或者是否有另一种方法可以映射字段?
出于此问题的目的,这是一个简化的示例,因为这样映射字段名称将是理想的,而不是在给定位置插入值。