gpt4 book ai didi

显示总数的 SQL 查询

转载 作者:行者123 更新时间:2023-12-04 23:53:38 29 4
gpt4 key购买 nike

我有一个非常复杂的查询,它连接了八 (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_|

我在这里整理了一个 fiddle :http://www.sqlfiddle.com/#!3/a3ce4/1

我被告知他们并不真的需要这个 PacketIDRequestID,但他们需要的是显示一个数据包中有多少请求以及什么请求的东西该数据包的数量需要注意。

我仍然需要 PacketIDRequestID 值才能更改数据。

所以,我想在上面的表格中添加一列,如下所示:

|_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 上定义的完整 View ,这里是:

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)

screenshot

最佳答案

我不会只给你完整的答案,而是会尝试解释如何自己创建答案。

要获得连续的序列号,请查看 ROW_NUMBER .您可以按 (PacketID) 提供分区,按 (RequestId) 提供订单。这将为您提供所需的第一个号码。

要获取计数,如果您使用的是 SQL Server 2012,则可以对分区使用 COUNT。在旧版本的 SQL Server 上,您将不得不使用 JOIN 和 GROUP BY 或子选择。

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

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

http://www.sqlfiddle.com/#!3/a3ce4/8

要获得您请求的确切格式,您只需将整数转换为字符串并将它们连接起来。我会把这个留给你去做,但这里有一些提示。

关于显示总数的 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13184746/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com