4

我在 Access 中有一个查询,其中一个字段包含一个子查询,该查询返回相关表中特定字段的总和。子查询的结果用于主查询中的进一步计算。

这在使用 ADO.Net 的 VB.Net(C# 很好)中的自制报告应用程序中使用。查询存储在 Access 的表中,以允许我们更正小错误或添加与数据相关的临时功能,而无需再次发布我们的应用程序。

问题是子查询可能没有返回结果(null)。此外,计算中使用的空值也将返回空值。因此,如果需要,我需要将空值替换为 0。我添加了NZ(subquery, 0),但 ADO.Net 抛出以下异常:

Undefined function 'NZ' in expression

我了解到不可能在 ADO.Net 中使用 VBA 函数,因为它是 Access.Application 对象的一部分。

我也考虑过使用IIF(subquery Is Null, 0, subquery),但这会迫使我复制子查询,并强制 Access 执行子查询两次(可能)。由于子查询相当复杂(主查询也是如此),我想避免这种情况,至少为了可读性,如果不是性能的话。

是否有另一种方法可以用另一个值替换空值,或者确保我的子查询即使没有匹配记录也将始终返回非空总和?

4

4 回答 4

6

对不起,没有别的办法。最干净的方法将是

Iif(IsNull([Data]), 0, [Data])

NZ 是 Access 代码库特有的功能,因此您将无法使用它。

于 2013-09-18T13:21:47.053 回答
3

尝试这个:

int? x = null;

// Set y to the value of x if x is NOT null; otherwise,
// if x == null, set y to -1.
int y = x ?? -1;

要了解更多信息,请参阅microsoft 帮助

于 2018-11-17T18:55:14.077 回答
1

尝试使用??如下所示:

         double? nullableVar=null;
         double nonNullableVar;
         nonNullableVar = (nullableVar ?? 0);
于 2015-08-06T20:56:39.483 回答
1

看看我的自定义函数 ez: Undefined function 'Nz' in expression。这里是:

Public Function ez(ByVal vVal1 As Variant, Optional ByVal vVal2 As Variant = 0) As Variant
    If VBA.IsNull(vVal1) Or VBA.Len(vVal1) = 0 Then
        ez = vVal2
    Else
        ez = vVal1
    End If
End Function

正如你所看到的,它比原始函数更进一步,因为它不仅考虑第二个值是否第一个为空,而且如果它为空

此外,默认返回值为 0,而 Nz 为空字符串。

于 2019-12-08T12:07:45.050 回答