加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server中咋用sql语句join all优化or查询

发布时间:2023-06-10 11:13:03 所属栏目: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毫秒

上述内容具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助。

(编辑:银川站长网)

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

    推荐文章