3

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_|

ここでフィドルをまとめました:http://www.sqlfiddle.com/#!3/a3ce4/1

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)

スクリーンショット

4

2 に答える 2

3

答え全体を提供するのではなく、自分で答えを作成する方法を説明しようと思います。

連続したシーケンス番号を取得するには、を参照してくださいROW_NUMBER。(PacketID)でパーティションを提供し、(RequestId)で注文を提供できます。これにより、必要な最初の番号が得られます。

カウントを取得するには、SQL Server 2012を使用COUNTしている場合は、パーティションで使用できます。古いバージョンのSQLServerでは、JOINとGROUPBYまたは副選択を使用する必要があります。

このクエリは、副選択アプローチを使用した原則を示しています。

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

要求した正確な形式を取得するには、整数を文字列に変換して連結する必要があります。これはあなたに任せますが、ここにいくつかのヒントがあります。

于 2012-11-01T20:16:57.897 に答える
2

@MarkByersrow_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
于 2012-11-01T20:20:46.273 に答える