-
sql语句大全之SQL优化:使用查询提示
先从一个问题开始:
刚在MSDN上看到对Option的解释为:指定应在整个查询中使用所指定的查询提示。 每个查询提示只能指定一次,但允许指定多个查询提示。 使用该语句只能指定一个 OPTION 子句。
请问如下问题:
1.查询提示是什么意思?
2."每个查询提示只能指定一次,但允许指定多个查询提示"这又是什么意思?
3.Option中经常用(fast 整数),请问其中的fast和整数分别是什么意思?
4.SELECT语句中用Option子语句后好象会提高整个语句的速度吗?
1、查询提示是sql server提供的,用于修改查询优化器行为的一种参数,之所以sql server 要提供这个,主要是由于,有时候sql server不能产生最优化的执行计划,于是,你可以通过这个查询提示,来告诉优化器,要采用何种算法。
2、每个查询提示只能用一次,但允许使用多个查询提示。
查询提示有N多种,比如:hash join,merge union ,fast N,maxdop N ,有一大堆。
你不能在一个查询中指定多次 hash join,但你可以指定hash join,又指定 maxdop n,但你不能指定hash join两次,那就好报错啦。
比如:
select *
from
(
select 'abc' as v,1 as vid
union all
select 'cd',2
)a
inner join
(
select 'cd' as v,2 as vid
union all
select 'abc',1
)b
on a.vid = b.vid
option(hash join,maxdop 2)
3、FAST number_rows
指定对查询进行优化,以便快速检索第一个 number_rows.。该值是非负整数。在返回第一个number_rows 后,查询继续执行并生成完整的结果集。
这个一般用于那种分页的查询,比如查询结果一共100行,指定number_rows为10,那就是采用最快返回前10行的算法,当然后面的90也会返回,也就是他对这些返回的数据,采用了优先级,SQL SERVER 生成了优先返回10行的算法,而不是一次性返回100行的算法。
4、关于是否能提高性能这个说法,我在实际工作中经常用,有时候效果非常明显,特别是对于表关联的查询提示,或者是联接提示。
很多时候,同事说这个查询太慢要5分钟才能查询出结果,于是加上了inner hash join后,只要5秒就能返回结果,火箭般的速度,但有时候加了效果不大,所以这个你可以多试试,
比如:
select *
from
(
select 'abc' as v,1 as vid
union all
select 'cd',2
)a
inner join
(
select 'cd' as v,2 as vid
union all
select 'abc',1
)b
on a.vid = b.vid
option(hash join)
select *
from
(
select 'abc' as v,1 as vid
union all
select 'cd',2
)a
inner hash join --这个联接提示,更为灵活,适用于多表关联
(
select 'cd' as v,2 as vid
union all
select 'abc',1
)b
on a.vid = b.vid
---------------------
作者:不想长大啊
来源:CSDN
原文:https://blog.csdn.net/sqlserverdiscovery/article/details/60758218
版权声明:本文为博主原创文章,转载请附上博文链接!
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式