サブセレクトをパイプライン化された関数呼び出しに一般的に変換するにはどうすればよいですか?
たとえば、これをどのように翻訳しますか:
select id, stuff from t1 where id in (select unique id from kw where k = 'foo')
これに:
select id, stuff from t1 where id in (select id from table(has_kw('foo'))
サブセレクトをパイプライン化された関数呼び出しに一般的に変換するにはどうすればよいですか?
たとえば、これをどのように翻訳しますか:
select id, stuff from t1 where id in (select unique id from kw where k = 'foo')
これに:
select id, stuff from t1 where id in (select id from table(has_kw('foo'))
パイプライン化されたテーブル関数の記述は比較的簡単です
CREATE TYPE num_tbl AS TABLE OF NUMBER;
CREATE FUNCTION has_kw( p_k IN VARCHAR2 )
RETURN num_tbl
PIPELINED
IS
BEGIN
FOR i IN (SELECT DISTINCT id FROM kw WHERE k = p_k)
LOOP
PIPE ROW( i.id );
END LOOP;
RETURN;
END;
さて、ここで pipeliend テーブル関数を使用することが本当に意味があるかどうかはわかりません。しかし、おそらく実際のユースケースはもっと複雑で、パイプライン化されたテーブル関数の方が適切でしょう。