我正在尝试使用linq连接两个数据表
var invoices420 = dt420_.AsEnumerable();
var invoices430 = dt430_.AsEnumerable();
var query = from inv430 in invoices430
join inv420 in invoices420 on inv430.LinkDoc equals inv420.LinkDoc
orderby inv430.SID
select new
{
LinkDoc = inv430.LinkDoc,
TotalIn = Math.Round(inv430.Credit, 2),
TotalOut = ((inv420 == null) ? 0 : Math.Round(inv420.Debit, 2))
};
联接似乎不是问题,但我得到一个错误“System.Data.DataRow”不包含“LinkDoc”的定义,并且找不到接受“System.Data.DataRow”类型的第一个参数的扩展方法“LinkDoc”(是否缺少using指令或程序集引用?)。
在不使用inv40.Field(“linkdoc”)的情况下引用DataTable中的列(例如inv430.LinkDoc ),我必须做什么?
如果我想对结果集执行group by,我会考虑
var q2 = query
.GroupBy(item => item.LinkDoc);
return q2.ToArray();
问题是在q2中我没有得到所有的列(linkdoc,totalin,totalout)。
原始数据是
dt420_
Linkdoc Credit
Invoice1 500
Invoice2 100
Invoice3 200
dt430_
LinkDoc Debit
Invoice1 100
Invoice1 100
Invoice2 200
Result would be
LinkDoc TotalIn(Credit) TotalOut(Debit)
Invoice1 500 200
Invoice2 100 200
Invoice3 200 0
发布于 2012-11-11 09:38:55
您需要将直接调用的所有位置替换为属性,如
inv430.LinkDoc
至
inv430["LinkDoc"]
inv430是一个DataRow
,所以你需要使用获取字符串的索引器。
编辑:您的连接将带来错误的数据(请参阅下面的评论)。您需要使用以下代码:
var group430 = from inv430 in invoices430
group inv430 by inv430["LinkDoc"].ToString().Trim() into g
select new
{
LinkDoc = g.Key.ToString().Trim(),
TotalOut = g.Sum(inv => Math.Round((decimal)inv["Debit"], 2))
};
var group420 = from inv420 in invoices420
group inv420 by inv420["LinkDoc"].ToString().Trim() into g
select new
{
LinkDoc = g.Key.ToString().Trim(),
TotalIn = g.Sum(inv => Math.Round((decimal)inv["Credit"], 2))
};
var result = from inv430 in group430
join inv420 in group420 on inv430.LinkDoc equals inv420.LinkDoc into inv
from inv420 in inv.DefaultIfEmpty()
select new
{
inv430.LinkDoc,
TotalOut = inv430.TotalOut,
TotalIn = inv420 != null ? inv420.TotalIn : 0
};
https://stackoverflow.com/questions/13329640
复制相似问题