我有一个包含10个以上列的数据表,我希望将所有列分开,然后将结果存储到另一个数据表中。
有没有办法在不命名所有列的情况下使用LINQ来区分数据表中的所有列?
我已经尝试过以下代码,但它只是给了一行。请给我这个案子的任何建议。
DataTable dtPurchaseOrder = new DataTable();
DataTable dt = new DataTable();
dt.Columns.Add("PONumber");
dt.Columns.Add("Customer");
dt.Columns.Add("Address");
dt.Rows.Add("PO123456", "MH", "123");
dt.Rows.Add("PO123456", "MH", "123");
dt.Rows.Add("PO654321", "AB", "123");
dt.Rows.Add("PO654321", "AB", "123");
foreach (DataRow r in dt.Rows)
{
var lstPO = (from row in dtPurchaseOrder.AsEnumerable()
select row.Field<string>("PONumber")).Count();
if (lstPO == 0)
dtPurchaseOrder.Rows.Add(r.ItemArray);
}
dtPurchaseOrder.AcceptChanges();
答案 0 :(得分:4)
解决方案1:
最简单的解决方案是DefaultView.ToTable
。
dt.DefaultView.ToTable(true, "PONumber", "Customer", "Address");
解决方案2:
另一种方法是使用Linq
语句过滤不同的行,然后根据需要循环它们。
var result = dt.AsEnumerable()
.Select(row => new {
PONumber = row.Field<string>("PONumber"),
Customer = row.Field<string>("Customer"),
Address = row.Field<string>("Address")
}).Distinct();
解决方案3:
通过定义PrimaryKey
检查存在的传统方式。
var ponum = dtPurchaseOrder.Columns.Add("PONumber");
var cust = dtPurchaseOrder.Columns.Add("Customer");
var address = dtPurchaseOrder.Columns.Add("Address");
dtPurchaseOrder.PrimaryKey = new[] {ponum, cust, address};
dt.Rows.Add("PO123456", "MH", "123");
dt.Rows.Add("PO654321", "AB", "123");
dt.Rows.Add("PO654321", "AB", "123");
foreach (DataRow r in dt.Rows)
{
var exisiting = dtPurchaseOrder.Rows.Find(r.ItemArray);
if (exisiting == null)
{
dtPurchaseOrder.Rows.Add(r.ItemArray);
}
}
工作Sample
答案 1 :(得分:2)
在不定义列名称的情况下区分表的方法
var dtPurchaseOrder = dt
.AsEnumerable()
.Distinct(DataRowComparer.Default)
.CopyToDataTable<DataRow>();