首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这个sql查询可以简化吗?

这个sql查询可以简化吗?
EN

Stack Overflow用户
提问于 2010-01-24 00:47:15
回答 3查看 110关注 0票数 1

我有一个Sql查询:

代码语言:javascript
复制
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

EN

回答 3

Stack Overflow用户

发布于 2010-01-24 00:54:17

这并不是很简单(就代码而言),但性能会更好,因为您使用的是joins而不是IN运算符:

代码语言:javascript
复制
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限制的评论),那么您可以将部分逻辑抽象到视图中,例如

代码语言:javascript
复制
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中使用该视图。

票数 2
EN

Stack Overflow用户

发布于 2010-01-24 01:06:10

如前所述,WHERE子句中的子选择是不同的。

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

一些想法:

  • 您可以为子选择(或子选择,如果两者之间的差异是故意的)创建一个视图,这将减少查询的查询计划的verboseness.
  • Get,并使用全文索引查找表scans.
  • Consider,而不是在模式的开头使用通配符,因为这需要扫描整个索引(假设列上有索引) --如果没有索引,则添加一个。
票数 2
EN

Stack Overflow用户

发布于 2010-01-24 00:56:51

试试这个:

代码语言:javascript
复制
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%')
)
)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2123863

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档