显示总计计数的SQL查询

显示总计计数的SQL查询,sql,tsql,ssms,Sql,Tsql,Ssms,我有一个非常复杂的查询,它连接八(8)个不同的表 但是,为了解决这个问题,我将使用这种结构对其进行简化: create table table1(PacketID int, RequestID int, EmpID int, PartNo varchar(20)) insert into table1 values (1 , 1, 132, 'abc123'), (1 , 2, 132, 'abc456'), (1 , 3, 132, 'def123'), (1 , 4, 132, '

我有一个非常复杂的查询,它连接八(8)个不同的表

但是,为了解决这个问题,我将使用这种结构对其进行简化:

create table table1(PacketID int, RequestID int, EmpID int, PartNo varchar(20))

insert into table1 values
 (1 , 1, 132, 'abc123'),
 (1 , 2, 132, 'abc456'),
 (1 , 3, 132, 'def123'),
 (1 , 4, 132, 'def456'),
 (2 , 5, 228, 'xyz123'),
 (3 , 6, 239, 'xyz321'),
 (3 , 7, 239, 'aaa000')
此类型的表将创建以下输出:

|_P_|_R_|_Emp_|_PartNo_|
|_1_|_1_|_132_|_abc123_|
|_1_|_2_|_132_|_abc465_|
|_1_|_3_|_132_|_def123_|
|_1_|_4_|_132_|_def456_|
|_2_|_5_|_228_|_xyz123_|
|_3_|_6_|_239_|_xyz321_|
|_3_|_7_|_239_|_aaa000_|
我在这里整理了一把小提琴:

我被告知他们并不真正需要这个
PacketID
RequestID
,但他们真正需要的是显示一个数据包中有多少个请求以及该数据包的请求号需要注意

我仍然需要
PacketID
RequestID
值来更改数据

因此,我想在上表中添加一列,如下所示:

|_P_|_R_|_ReadAs_|_Emp_|_PartNo_|
|_1_|_1_|_1 of 4_|_132_|_abc123_|
|_1_|_2_|_2 of 4_|_132_|_abc465_|
|_1_|_3_|_3 of 4_|_132_|_def123_|
|_1_|_4_|_4 of 4_|_132_|_def456_|
|_2_|_5_|_1 of 1_|_228_|_xyz123_|
|_3_|_6_|_1 of 2_|_239_|_xyz321_|
|_3_|_7_|_2 of 2_|_239_|_aaa000_|
我该怎么做呢

如果您只是想感受我的痛苦,并查看在我的SQL Server上定义的完整视图,请参阅以下内容:

SELECT P.ID AS PacketID, R.ID AS RequestID, A.ID AS ActionID,
  EI.FIRSTNAME + ' ' + EI.LASTNAME AS Employee, P.DateStamp, 
  RQ.Description AS RequestType, L.Description AS Line, R.PartNo,
  R.Workorder, R.Qty, RZ.Description AS ReasonType, R.MTF,
  A.StatusID, S.Description AS Status, A.EmpID AS Stator, 
  A.DateStamp AS Stated
FROM dbo.Packet AS P
  LEFT OUTER JOIN dbo.Request AS R ON R.PacketID = P.ID
  INNER JOIN dbo.Action AS A ON R.ID = A.RequestID
  LEFT OUTER JOIN dbo.Action AS A2 ON A.RequestID = A2.RequestID
         AND (A.DateStamp < A2.DateStamp OR
         A.DateStamp = A2.DateStamp AND A.RequestID < A2.RequestID)
  INNER JOIN CPAPP.AIO_Test_Results.dbo.EmployeeInfo AS EI ON A.EmpID = EI.COUNT
  INNER JOIN dbo.RequestType AS RQ ON R.RequestTypeID = RQ.ID
  INNER JOIN dbo.Line AS L ON R.LineID = L.ID
  INNER JOIN dbo.ReasonType AS RZ ON R.ReasonTypeID = RZ.ID
  INNER JOIN dbo.Status AS S ON A.StatusID = S.ID
WHERE (A2.RequestID IS NULL)
选择P.ID作为PacketID,R.ID作为RequestID,A.ID作为ActionID,
EI.FIRSTNAME+“”+EI.LASTNAME作为员工,P.邮戳,
RQ.描述为请求类型,L.描述为行,R.零件号,
R.工单、R.数量、RZ.描述为ReasonType、R.MTF、,
A.StatusID,S.描述为状态,A.EmpID为定子,
A.注明的邮戳
来自dbo.Packet作为P
左外部联接dbo.Request作为R.PacketID=P.ID上的R
内部连接dbo.Action作为R.ID=A.RequestID上的
在A.RequestID=A2.RequestID上作为A2的左外部联接dbo.Action
和(A.邮戳

我将尝试解释如何自己创建答案,而不仅仅是给出完整的答案

要获得连续序列号,请查看。您可以提供分区依据(PacketID)和订单依据(RequestId)。这会让你得到你需要的第一个号码

要获取计数,如果您使用的是SQL Server 2012,则可以对分区使用
COUNT
。在旧版本的SQL Server上,必须使用联接和分组依据或子选择

此查询演示了使用子选择方法的原则:

SELECT
    PacketID,
    RequestID,
    EmpID,
    PartNo,
    ROW_NUMBER() OVER (PARTITION BY PacketID ORDER BY RequestID),
    (SELECT COUNT(*) FROM table1 AS T2 WHERE T1.PacketId = T2.PacketId)
FROM table1 AS T1

要获得所请求的确切格式,只需将整数转换为字符串并将其串联。我把这件事留给你做,但这里有一些提示


正如@MarkByers提到的,
row\u number()
在这里特别有用,我添加了一个相关子查询来获取每个数据包的计数:

select PacketID, RequestID
    , cast(RowNumber as varchar(11)) + ' of ' + cast(PacketCount as varchar(11)) as ReadAs
    , EmpID, PartNo
from (
    select PacketID, RequestID, EmpID, PartNo
        , row_number() over (partition by PacketID order by RequestID) as RowNumber
        , (select count(*) from table1 where PacketID = t.PacketID) as PacketCount
    from table1 as t
) as z