[英]Can this sql query be simplified?
我有一个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
这实际上并不简单(在代码方面),但是性能更高,因为您使用的是连接而不是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中使用该视图。
如上所述,WHERE子句中的子选择不一样。
我不确定你的意思是什么“简化”,以什么方式简化? 不那么冗长? 不太复杂的查询计划? 更多表现? 换句话说,你想解决什么问题?
一些想法:
您可以为您的子选择创建一个视图(或者如果两者之间的差异是有目的的,则进行子选择),这将减少冗长。
获取查询的查询计划并查找表扫描。
考虑在模式的开头使用全文索引而不是LIKE和外卡,因为这需要扫描整个索引(假设列上有索引) - 如果没有索引则添加一个索引。
尝试这个:
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%')
)
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.