Sql server 显示每行的计数,根据特定条件计算有多少行
我很好奇您是否知道如何轻松地选择一个“父项”中有多少“子项”的计数,并在每一行上显示该计数,同时将子项保持为表的唯一键 目前我选择的表格如下:Sql server 显示每行的计数,根据特定条件计算有多少行,sql-server,sql-server-2012,Sql Server,Sql Server 2012,我很好奇您是否知道如何轻松地选择一个“父项”中有多少“子项”的计数,并在每一行上显示该计数,同时将子项保持为表的唯一键 目前我选择的表格如下: SELECT OBJECTID, PARENTID FROM CURRENTTABLE 这是我得到的结果: CURRENTTABLE: OBJECTID, PARENTID OBJECT1, PARENT1 OBJECT2, PARENT1 OBJECT3, PARENT2 OBJECT4, PARENT2 OBJECT5, PARENT2 但我希望
SELECT OBJECTID, PARENTID
FROM CURRENTTABLE
这是我得到的结果:
CURRENTTABLE:
OBJECTID, PARENTID
OBJECT1, PARENT1
OBJECT2, PARENT1
OBJECT3, PARENT2
OBJECT4, PARENT2
OBJECT5, PARENT2
但我希望它看起来像这样,因为Parent1中有2个对象,Parent2中有3个对象
CURRENTTABLE:
OBJECTID, PARENTID, COUNTOBJECTSWITHINPARENT
OBJECT1, PARENT1, 2
OBJECT2, PARENT1, 2
OBJECT3, PARENT2, 3
OBJECT4, PARENT2, 3
OBJECT5, PARENT2, 3
有没有办法轻松做到这一点
亲切问候,,
Igor您是否查看了
COUNT
和OVER
子句?如果没有,你试过什么?为什么不起作用呢?一个简单的子查询可以很容易地做到这一点。你看过COUNT
和OVER
子句了吗?如果没有,你试过什么?为什么不起作用?一个简单的子查询可以很容易地做到这一点。
SELECT OBJECTID,
PARENTID,
COUNT(*) OVER (PARTITION BY PARENTID) as COUNTOBJECTSWITHINPARENT
FROM CURRENTTABLE