T-SQLに問題があり、解決するのが難しいと感じています。
key1とkey2でグループ化されたレコードのグループを含むテーブルがあります。各グループを日付順に時系列で並べ替えます。各レコードについて、フィールド「データフィールド」が現在のレコードの「データフィールド」との許可された組み合わせを形成するレコードが以前に(グループ内で、日付が低い)存在したかどうかを確認したいと思います。許可された組み合わせについては、AllowedCombinationsTableというテーブルがあります。
私はそれを達成するために次のコードを書きました:
WITH Source AS (
SELECT key1, key2, datafield, date1,
ROW_NUMBER() OVER(PARTITION BY key1, key2 ORDER BY date1 ASC) AS dateorder
FROM table
)
SELECT L.key1, L.key2, L.datafield, DC.datafield2
FROM Source AS L
LEFT JOIN AllowedDataCombinationsTable DC
ON D.datafield1 = L.datafield
LEFT JOIN Source AS R
ON R.Key1 = L.Key1
AND R.Key2 = L.Key2
AND R.dateorder < L.dateorder
AND DC.datafield2 = L.datafield
-- AND "pick the one record with lowest dateorder"
次に、これらの可能な組み合わせレコードのそれぞれについて、最初のレコードを選択します(コードのプレースホルダーを参照)。どうすれば最も効率的にそれを行うことができますか?
編集:OK、ソースについて考えてみましょう。グループ(1、1)のみが表示されます。
**Key1 Key2 Datafield Date DateOrder**
1 1 "Horse" 1-Jan-2010 1
1 1 "Horse" 2-Jan-2010 2
1 1 "Sheep" 3-Jan-2010 3
1 1 "Dog" 4-Jan-2010 4
1 1 "Cat" 5-Jan-2010 5
AllowedCombinationsTable:
**Datafield1 Datafield**
Cat Sheep (and Sheep Cat)
Cat Horse (and Horse Cat)
Dog Horse (and Horse Dog)
私の参加後、私は今持っています:
**Key1 Key2 Datafield Date DateOrder JoinedCombination JoinedCombinationDateOrder**
1 1 "Horse" 1-Jan-2010 1 NULL NULL
1 1 "Horse" 2-Jan-2010 2 NULL NULL
1 1 "Sheep" 3-Jan-2010 3 NULL NULL
1 1 "Dog" 4-Jan-2010 4 "Horse" 1
1 1 "Dog" 4-Jan-2010 4 "Horse" 2
1 1 "Cat" 5-Jan-2010 5 "Horse" 1
1 1 "Cat" 5-Jan-2010 5 "Horse" 2
1 1 "Cat" 5-Jan-2010 5 "Sheep" 3
レコード4「犬」の最初の「馬」とレコード5「猫」の最初の「馬」だけを表示したい。
それを得る?;)