3

我正在尝试对 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)

我注意到即使我在可交付成果中有值(添加用于测试)并且当值匹配时查询将正确执行,但是当可交付成果中没有匹配时,那是我收到错误消息的时候。

问题可能与处理空值有关。

4

3 回答 3

4

我认为x是 null 并导致NullReferenceException以下几行:

collumn_attr = (string)(x.b == null ? string.Empty : x.b),
value = (int)(x.ACAP == null ? (int?)null : x.ACAP)

这个判断是基于from x in线路的DefaultIfEmpty()调用,典型的左外连接。

在数据库代码中,您会编写类似的东西x.ACAP == null来检测没有匹配的连接元素的情况。如果你改变这个,用“x == null”检查替换“x.property == null”检查,我怀疑你的问题会解决。

第二行仍然存在问题 - 如果您尝试将值强制(int?)null转换为整数,您将在运行时遇到异常。在这种情况下使用有意义的默认int值(例如 0)x == null可以清除该值。

于 2012-08-25T01:27:39.073 回答
1

如果您单步执行您的代码,在执行查询之前,您是否真的看到“可交付成果”和“参考”被填充了数据?

调查您在查询中使用的所有子表/属性。您收到该错误的原因很可能是因为您在比较时使用的属性之一为空。.RefType .Comment 例如。也许 .RefType 为 null 并且在最后排序时遇到问题。很难说没有看到这两个系列中有什么。

在您的评论后添加:

请注意,当您的变量可能为空时,最好不要使用 .Equals()。使用 == 代替。参考: http: //www.dotnetperls.com/string-equals

还可以想象(x.ACAP == null ? (int?)null : x.ACAP)返回一个null. 您正在将整个内容转换为 int : value = (int)(x.ACAP == null ? (int?)null : x.ACAP)。转换null为 nint显然会失败

于 2012-08-24T19:28:03.443 回答
0

仅作记录,C# 6.0 中新的 Null 条件运算符可以这样使用:

                collumn_attr = x?.b ?? string.Empty,
                value = x?.ACAP
于 2016-02-11T16:13:17.457 回答