幕布斯7119047
是的,“count”函数本身的返回值始终是非null整数,无例外。话虽如此,您可能对查询的返回值更感兴趣,这实际上是一个结果集。如果是这种情况,那么您只需要考虑您的查询是否包含“group by”子句。一个非分组查询中包含聚合函数select count(*), sum(*), max(*), min(*) from table生成具有单个记录的结果集包含聚合函数的返回值。在这种情况下,结果集将始终只有一条记录,其中的列包含您包含的任何聚合函数的返回值。在此单独记录中,count的返回值将始终为非null整数,而其他聚合函数(如min,max和sum)的返回值可能为null。在上面的示例中,您返回的记录可能是“零,null,null,null”,但永远不会是“null,null,null,null”,因为count永远不会返回null。因此,如果您只调用“count”,那么返回的那一条记录中的那一列将始终包含count的非null返回值; 因此,您可以放心,计数查询的标量返回值将始终为非空整数。另一方面,具有聚合函数的分组查询select count(*), sum(*), max(*), min(*) from table group by column生成具有零个或多个记录的结果集,其中每个记录包含所标识的每个组的聚合函数的返回值。在这种情况下,如果没有标识组,则没有用于运行聚合函数的组,函数永远不会运行,并且“查询返回值”将是一个空集,根本没有记录。在没有记录的表上测试它以查看结果:create table #t (c int);select COUNT(c), MIN(c), MAX(c), SUM(c) from #t; --returns one record {0, null, null, null}select COUNT(c), MIN(c), MAX(c), SUM(c) from #t group by c; --returns no recordsdrop table #t;因此,无论您是调用count,min,max还是sum,重要的是不仅要了解各个聚合函数的返回值,还要了解查询本身的“返回值”以及结果集包含的内容。