17

次のようなクエリがあります

select columns
from (select columns1
      from result_set
      where condition_common and condition1) as subset1
      join
      (select columns2
       from result_set
       where condition_common and condition2) as subset2 
      on subset1.somekey = subset2.somekey

何とか再利用したい

select columns
from result_set
where condition_common

上記のクエリを単純化しすぎましたが、実際には上記の選択は巨大で複雑です。両方が同期していることを確認する負担を負いたくない

プログラムで再利用する手段がありません。T-SQL は除外されます。簡単なクエリしか書けません。これはアプリの制限です。

単一のステートメントで同じサブクエリを再利用する方法はありますか

4

1 に答える 1

32

SQL Server 2005 以降を使用している場合は、共通テーブル式(CTE) を使用します。

with cte as (
      select columns
      from result_set
      where condition_common
    )
select columns
from cte  as subset1
      join
      cte as subset2 
         on subset1.somekey = subset2.somekey
where otherconditions
于 2013-02-20T18:31:36.793 に答える