首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL优化问题

SQL优化问题
EN

Stack Overflow用户
提问于 2012-02-03 00:14:02
回答 3查看 79关注 0票数 3

我有两张桌子。一个表包含有关资产的信息,另一个表包含它们之间的关系。如何优化当前查询并获得相似的结果。

代码语言:javascript
复制
SELECT a1.ID FROM Asset a1
WHERE a1.AssetId =
(SELECT r.DestinationAssetId
FROM Relation r
INNER JOIN Asset a2 ON a2.AssetId = r.SourceAssetId
WHERE a2.ID = '1112174' and r.RelationshipType = 'Video File')

结果: 13412331 (与a2.ID =‘1125574’相关的资产ID)

就我个人而言,我不喜欢这个愚蠢的子查询,有没有什么方法可以避免它并优化这个查询。

谢谢!

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-02-03 00:20:12

您可以丢失子查询:

代码语言:javascript
复制
SELECT dest.ID 
FROM 
Asset src
JOIN Relation r ON src.AssetId = r.SourceAssetId
JOIN Asset dest ON dest.AssetID = r.DestinationAssetID
WHERE src.ID = '1112174' and r.RelationshipType = 'Video File'

这并不是性能上的优化,但它更简洁一些。

票数 4
EN

Stack Overflow用户

发布于 2012-02-03 00:21:24

乍一看,这看起来会做同样的事情:

代码语言:javascript
复制
SELECT a1.ID
FROM Relation r
INNER JOIN Asset a2 ON a2.AssetId = r.SourceAssetId
INNER JOIN Asset a1 ON a1.AssetId = r.DestinationAssetId
WHERE a2.ID = '1112174' and r.RelationshipType = 'Video File'
票数 2
EN

Stack Overflow用户

发布于 2012-02-03 00:20:53

试试这个:

代码语言:javascript
复制
SELECT a1.ID
FROM Asset a1
INNER JOIN Relation r ON a1.AssetId = r.DestinationAssetId
INNER JOIN Asset a2 ON a2.AssetId = r.SourceAssetId
WHERE a2.ID = '1112174' and r.RelationshipType = 'Video File'
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9115748

复制
相关文章

相似问题

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