1

私はSQLクエリを持っています:

select * from contactmeta
WHERE
contactmeta.contact_id in 
(
select tob.object_id from tagobject tob, tag t, taggroup tg 
where tob.tag_id = t.tag_id
and t.tag_group_id = tg.tag_group_id
and tob.object_type_id = 14 
and tg.org_id = contactmeta.group_id 
and (t.name like '%campaign%')
)
AND
contactmeta.contact_id in 
(
select tob.object_id from tagobject tob, tag t, taggroup tg 
where tob.tag_id = t.tag_id 
and t.tag_group_id = tg.tag_group_id
and tob.object_type_id = 14 
and tg.org_id = contactmeta.group_id 
and (t.name like '%bounced%')
)

私の問題は、WHERE 句内のクエリの部分を単純化する必要があることです (contactmeta テーブルなどと別の結合を行うことはできません)。これは、静的な SQL に対して WHERE 句が動的に作成されるためです。

t.name 条件を除いて、両方の where 条件がほぼ同じであることがわかります。

御時間ありがとうございます

SK

4

3 に答える 3

2

前述のように、WHERE 句のサブセレクトは同じではありません。

「単純化された」とはどういう意味ですか。どのように単純化されていますか? 冗長ではありませんか?複雑でないクエリ プラン?より多くのパフォーマンス?言い換えれば、どのような問題を解決しようとしていますか?

いくつかのアイデア:

  • 冗長性を減らす副選択 (または 2 つの違いが意図的なものである場合は副選択) のビューを作成できます。

  • クエリのクエリ プランを取得し、テーブル スキャンを探します。

  • パターンの先頭にワイルド カードを使用して LIKE ではなく全文インデックスを使用することを検討してください。これは、インデックス全体をスキャンする必要があるためです (列にインデックスがあると仮定します)。インデックスがない場合は、インデックスを追加します。

于 2010-01-23T17:06:10.260 に答える
2

これは実際には(コードの観点から)単純ではありませんが、IN演算子ではなく結合を使用しているため、パフォーマンスは向上します。

select contactmeta .* from contactmeta 

inner join tagobject tob, tag t, taggroup tg  
on tob.tag_id = t.tag_id 
and t.tag_group_id = tg.tag_group_id 
and tob.object_type_id = 14  
and tg.org_id = contactmeta.group_id  
and (t.name like '%campaign%')

inner join tagobject tob2, tag t2, taggroup tg2  
on tob2.tag_id = t2.tag_id 
and t2.tag_group_id = tg2.tag_group_id 
and tob2.object_type_id = 14  
and tg2.org_id = contactmeta.group_id  
and (t2.name like '%bounced%') 

EDIT:それが不可能な場合(JOIN制限に関するコメントのために)、ロジックの一部をビューに抽象化できます。

create view myView 
as
select * from tagobject tob, tag t, taggroup tg  
    on tob.tag_id = t.tag_id 
    and t.tag_group_id = tg.tag_group_id

元のSQLでそのビューを使用します。

于 2010-01-23T16:54:16.837 に答える
0

これを試して:

select * from contactmeta
WHERE
contactmeta.contact_id in 
(
select tob.object_id from tagobject tob, tag t, taggroup tg 
where tob.tag_id = t.tag_id
and tob.object_type_id = 14 
and tg.org_id = contactmeta.group_id 
and (
   (t.tag_group_id = tg.tag_group_id and t.name like '%campaign%')
   or
   (tob.tag_id = t.tag_id and t.name like '%bounced%')
)
)
于 2010-01-23T16:56:50.900 に答える