0

MSSQL のテーブルの各間隔の最初と最後のレコードのみを取得するには、MSSQL のクエリを作成する必要があります。たとえば、次の表があります

ID | label_id

1 | A1

2 | A2

3 | A3

4 | A4

5 | A10

6 | A11

7 | A13

結果は次のように表示される必要があります

label_id_start | label_id_start | カウント

A1         |       A4          |   4
A10        |       A11         |   2
A13        |       A13         |   1

解決策を探していましたが、今まで何も見つかりませんでした。

ありがとう

4

1 に答える 1

0

そのような解決策はオプションです。ただし、WITH 構文には再帰の深さに制限があることに注意してください。最大再帰サイズは 200 まで増やすことができます。OPTION (MAXRECURSION 200)

DECLARE @MyTable TABLE (Iteration INT, Label VARCHAR(50))

INSERT INTO @MyTable(Iteration, Label)
VALUES
    (1, 'A1'),
    (2, 'A2'),
    (3, 'A3'),
    (4, 'A4'),
    (5, 'A10'),
    (6, 'A11'),
    (7, 'A13')

DECLARE @RefinedTable TABLE (LabelId INT, Label VARCHAR(50))

INSERT INTO @RefinedTable(LabelId, Label)
SELECT CAST(REPLACE(Label, 'A', '') AS INT) AS LabelNo, Label 
FROM @MyTable


DECLARE @Queue TABLE (Parent VARCHAR(50), Child VARCHAR(50))

INSERT INTO @Queue(Parent, Child)
SELECT t1.Label, t2.Label
FROM @RefinedTable t1
LEFT OUTER JOIN @RefinedTable t2
    ON t1.LabelId + 1 = t2.LabelId;

WITH Checker(Parent, Child, LastItem, Depth)
AS
(
    SELECT Parent, CAST(NULL AS VARCHAR(50)), Parent, 0  
    FROM @Queue
    WHERE Child IS NULL
    UNION ALL
    SELECT q.Parent, q.Child, c.LastItem, c.Depth + 1
    FROM @Queue q
    INNER JOIN Checker c
        ON c.Parent = q.Child 
)
SELECT 
    'A' + CAST(CAST(REPLACE(LastItem, 'A', '') AS INT) - MAX(Depth) AS VARCHAR) StartLabel,
    LastItem EndLabel,
    COUNT(*) AS [Count] 
FROM Checker
GROUP BY LastItem
ORDER BY 1
于 2013-03-13T12:58:22.647 に答える