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 表等进行另一个联接)。这是因为 WHERE 子句是在静态 sql 上动态创建的。

您可以看到除了 t.name 条件之外,两个 where 条件几乎相同。

谢谢你的时间

SK

4

3 回答 3

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%') 

编辑:如果这是不可能的(由于您对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 回答
2

如前所述,WHERE 子句中的子选择不一样。

我不确定您所说的“简化”是什么意思,以何种方式简化?不那么冗长?不太复杂的查询计划?更多性能?换句话说,你想解决什么问题?

一些想法:

  • 您可以为您的子选择(或子选择,如果两者之间的差异是故意的)创建一个视图,这将减少冗长。

  • 获取查询的查询计划并查找表扫描。

  • 考虑在模式的开头使用全文索引而不是带有通配符的 LIKE,因为这需要扫描整个索引(假设列上有索引)——如果没有索引,则添加一个。

于 2010-01-23T17:06:10.260 回答
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 回答