我有一个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
发布于 2010-01-24 00:54:17
这并不是很简单(就代码而言),但性能会更好,因为您使用的是joins而不是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-24 01:06:10
如前所述,WHERE子句中的子选择是不同的。
我不确定你所说的“简化”是什么意思,以什么方式简化?不那么罗嗦?不那么复杂的查询计划?更多的性能?换句话说,你想解决什么问题?
一些想法:
发布于 2010-01-24 00:56:51
试试这个:
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%')
)
)https://stackoverflow.com/questions/2123863
复制相似问题