select
a.编号
,a.编码
,a.年度
,count(*) 级别
,len(编码) - isnull(
(select max(len([父级编码]))
from 层级表 b
where a.编码 = b.编码 and a.编号=b.编号
and a.编码 <> b.父级编码
) ,0) 本级长度
from 层级表 a
group by a.编号,a.年度,a.编码
这一句,在取本级长度字段时,isnull 函数里嵌套了一次子查询
这里很明显是出现了一次a表和b表的笛卡尔积
是这样函数中嵌套的写法里会固定出现吗
如果这样的话,单纯的嵌套查询为什么没有笛卡尔积呢