加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server上怎么用sql语句join all优化or查询

发布时间:2023-04-14 14:21:56 所属栏目:MsSql教程 来源:
导读:这篇文章给大家分享的是“SQL Server中怎么用sql语句join all优化or查询”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。

比如:,master,test
这篇文章给大家分享的是“SQL Server中怎么用sql语句join all优化or查询”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。
 
比如:,master,test, 表示 该用户为 test 的下级代码,test登录后可以看到 test名下的业务和所有下级代理的业务。相关表的结构如下:
 
user表 大约10万条记录
 
|-uid-|-user-|----site------|
 
| 1 | test | ,master,   |
 
| 2 | user | ,master,test,|

product表 大约30万条记录
 
|-pid-|-product-|-puser-|
 
| 1 | order01 | test |
 
| 2 | order02 | user |
 
| 3 | order03 | user |
 
优化前的SQL语句如下:
 
select * from product as p left join user as u on p.puser=u.user where user='test' or site like '%,test,%'
 
不使用 or 单独查询时,都不超过100毫秒,排除索引的问题。既然单个没问题,两种结果不存在重复记录,可以考虑 join all 优化。
 
优化后的语句如下:
 
select * from product where pid in (
 
  select pid from product where user='test' join all (
 
    select pid from product as p left join user as u on p.puser=u.user where site like '%,test,%'
 
  )
 
)
 
用户A名下共有4000+个业务,优化前 优化前11359毫秒,优化后621毫秒
 
用户B名下共有12个业务,优化前 优化前10359毫秒,优化后78毫秒
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章