首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >创建多个连接表的视图比在查询中直接使用连接获取数据快吗?

创建多个连接表的视图比在查询中直接使用连接获取数据快吗?
EN

Stack Overflow用户
提问于 2010-09-21 15:21:46
回答 5查看 2.6K关注 0票数 1

以下是命中每个表有超过100,000条记录的查询。

代码语言:javascript
运行
复制
   SELECT b.login as userEmail, imgateway_instance_id as img, u.id as userId 
   FROM  buddy b
   INNER JOIN `user` u ON b.username = u.login
    INNER JOIN bot_to_buddy btb ON b.id = btb.buddy_id
    INNER JOIN bot ON btb.bot_id = bot.id
    WHERE u.id IN 14242
EN

回答 5

Stack Overflow用户

发布于 2010-09-23 15:56:22

对于记录数量与您的表一样多的表,使用连接通常会非常慢。这是因为joins将遍历表中的每条记录,这会使查询花费大量时间。

作为个人经验丰富的解决方案,我建议您尽量使用WHERE来过滤查询结果,然后使用连接来减少查询结果。

票数 1
EN

Stack Overflow用户

发布于 2010-09-21 15:54:41

不,您无法通过使用视图来获得性能。在后台,原始查询是在查询视图时运行的。

票数 0
EN

Stack Overflow用户

发布于 2010-09-21 16:07:39

有时使用视图可以获得一点性能,就像它在High Performance MySQL中所说的那样

另一方面,这本书的作者写了这个博客:Views as performance trouble maker

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3758096

复制
相关文章

相似问题

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