我正在尝试对 2 个对象执行左外连接并收到错误:对象引用未设置为对象的实例。
对象看起来像这样
var deliverables = OCHART.GetACAPValues(organization, ReportingPeriod, FiscalYear, "(09-10.10a) Outreach Significant").ToList();
var references = (from rf in OCHART.References where rf.RefType.Equals("09-10.10a") && rf.Comments.Equals("2") select rf).ToList();
其中可交付成果通常可能返回 0 条记录。不幸的是,我不能只是去连接数据库中的两个表,因此可交付成果必须是一个对象。
有人可以指出我正确的方向吗
谢谢,
我的代码是
var items = (from rf in references
join pt in deliverables on rf.Description equals pt.b into prt
from x in prt.Where(prt2 => prt2.a.Equals(audience)).DefaultIfEmpty()
where rf.RefType.Equals("09-10.10a") && rf.Comments.Equals("2")
select new
{
audience = (string)(audience == null ? "" : audience),
RefType = (string)(rf.RefType == null ? "" : rf.RefType),
RefOrder = (int)(rf.RefOrder == null ? 0 : rf.RefOrder),
refName = (string)(rf.Description == null ? "" : rf.Description),
collumn_attr = (string)(x.b == null ? string.Empty : x.b),
value = (int)(x.ACAP == null ? (int?)null : x.ACAP)
})
.OrderBy(o => o.RefOrder)
.Take(9)
.ToList();
编辑: 经过更多调试后,我的代码中的以下行似乎出现错误
collumn_attr = (string)(x.b == null ? string.Empty : x.b),
value = (int)(x.ACAP == null ? (int?)null : x.ACAP)
我注意到即使我在可交付成果中有值(添加用于测试)并且当值匹配时查询将正确执行,但是当可交付成果中没有匹配时,那是我收到错误消息的时候。
问题可能与处理空值有关。