15、SQL 查询并行优化全解析

SQL 查询并行优化全解析

1. 并行性与查询优化基础

在查询处理器执行并行查询计划之前,查询优化器需要先生成该计划。这个过程比串行查询计划的生成更为复杂。是否在查询计划中使用并行性,主要在查询处理器执行计划之前就已决定,这取决于实例级(或资源管理器工作负载组级)设置以及具体的查询。执行引擎在是否使用并行性方面的话语权较小,只有在 SQL Server 实例面临极端资源压力时才会否决并行性的使用。

2. 并行性设置

影响并行性的实例级设置有四个,可在 sys.configurations 目录视图中查看,并使用 sp_configure 系统存储过程进行配置:
- Affinity Mask :控制服务器的哪些逻辑处理器将映射到 SQLOS 调度程序。并行查询计划需要多个 SQLOS 调度程序,若该掩码设置为仅映射单个处理器,查询优化器将不会尝试生成并行查询计划。默认值为 0,表示所有逻辑处理器都应映射到 SQLOS 调度程序。
- Max Degree of Parallelism :是并行查询用于确定每个并行区域分配多少工作线程的默认值。可使用查询级 MAXDOP 提示覆盖此设置。默认值为 0,意味着并行计划的每个区域最多可使用 64 个在线 SQLOS 调度程序对应的线程数。
- Cost Threshold for Parallelism :查询优化器在优化查询计划时会经历多个阶段,此设置允许优化器在串行计划成本不够高时退出查询优化过程,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值