SQL Server的常用提示
在SQL Server中,有许多SQL语句的提示,本文总结一些比较常用的提示。
OPTION LOOP/MERGE/HASH JOIN提示
该提示可以改变整个SQL语句中所有JOIN的关联算法,所以请慎用!
下面语句中,我们使用OPTION(MERGE JOIN)提示,将SQL语句的两个JOIN都改为了MERGE JOIN:
SELECT *
FROM
[dbo].[Student]
INNER JOIN
[dbo].[City]
ON [City].StudentID=[Student].ID
INNER JOIN
[dbo].[Car]
ON [Car].StudentID=[Student].ID
OPTION(MERGE JOIN)
/*
三种JOIN的提示用法如下:
OPTION(LOOP JOIN) 将SQL语句中的所有JOIN改为LOOP JOIN
OPTION(MERGE JOIN) 将SQL语句中的所有JOIN改为MERGE JOIN
OPTION(HASH JOIN) 将SQL语句中的所有JOIN改为HASH JOIN
*/
查看执行计划,我们可以发现SQL语句中的两个JOIN的确都变为MERGE JOIN了:
关联JOIN提示
上面我们看到了用OPTION提示,是改变整个SQL语句所有JOIN的关联算法,比较危险,其实我们还可以对SQL语句中的单个JOIN声明关联算法。
声明[Student]表和[City]表之间,采用LOOP JOIN:
SELECT *
FROM
[dbo].[Student]
INNER LOOP JOIN
[dbo].[City]
ON [City].StudentID=[Student].ID
INNER JOIN
[dbo].[Car]
ON [Car].StudentID=[Student].ID
执行计划如下,我们可以看到,[Student]表和[City]表之间是使用的LOOP JOIN:
声明[Student]表和[City]表之间,采用MERGE JOIN:
SELECT *
FROM
[dbo].[Student]
INNER MERGE JOIN
[dbo].[City]
ON [City].StudentID=[Student].ID
INNER JOIN
[dbo].[Car]
ON [Car].StudentID=[Student].ID
执行计划如下,我们可以看到,[Student]表和[City]表之间是使用的MERGE JOIN:
声明[Student]表和[City]表之间,采用HASH JOIN:
SELECT *
FROM
[dbo].[Student]
INNER HASH JOIN
[dbo].[City]
ON [City].StudentID=[Student].ID
INNER JOIN
[dbo].[Car]
ON [Car].StudentID=[Student].ID
执行计划如下,我们可以看到,[Student]表和[City]表之间是使用的HASH JOIN:
可以看到采用单个JOIN的提示要比使用OPTION提示灵活很多。
锁定提示
在SQL语句中,我们还可以在表名后声明锁的类型和锁定级别,下面查询语句中,我们就声明了在表[Student]上使用排它锁WITH(XLOCK):
SELECT *
FROM
[dbo].[Student] WITH(XLOCK)
关于锁定提示,可以查看这篇文章,这里就不做过多的介绍了。
索引提示
在SQL语句中,我们还可以在表名后声明要使用表上的哪些索引,语法是
WITH(INDEX([索引名]))
如果要使用表上的多个索引,就用逗号分隔开即可:
WITH(INDEX([索引名1]),INDEX([索引名2]),INDEX([索引名3]))
如下SQL语句就声明了,我们要使用表[Student]的索引[IX_Index]和[IX_Student_Index_Code]:
SELECT *
FROM
[dbo].[Student] WITH(INDEX([IX_Index]),INDEX([IX_Student_Index_Code]))
执行计划如下,我们可以看到,该SQL语句,现在的确是使用了索引[IX_Index]和[IX_Student_Index_Code]:
我们还可以将锁定提示和索引提示结合在一起使用,如下所示:
SELECT Stu.*
FROM
[dbo].[Student] AS Stu WITH(XLOCK,TABLOCK,INDEX([IX_Index]))
我们声明了该SQL语句对表[Student]添加排它锁(XLOCK),并且排它锁的锁定级别为表锁(TABLOCK),并且我们要使用表[Student]的[IX_Index]索引(INDEX([IX_Index]))。这几个提示结合在一起使用,之间用逗号分隔开即可。
最后提醒下,SQL Server的提示并不是什么情况下都可以使用的,有时候使用提示会带来负面效果甚至报错,查看这里了解,所以在具体选择使用SQL Server提示的时候,要根据实际情况而定,不可以胡乱使用。
SQL Server的常用提示的更多相关文章
- 安装 SQL Server 2008 时提示需要删除 SQL Server 2005 Express 工具
已安装 SQL Server 2005,安装 SQL Server 2008 时提示需要删除 SQL Server 2005 Express 工具 错误提示:已安装 SQL Server 2005 E ...
- SQL Server 2000:提示“未与信任SQL SERVER连接相关连”错误
在使用“用户模式”登陆SQL Server 2000时提示“未与信任SQL SERVER连接相关连”错误,因为在安装SQL Server时选择“仅Windows”模式,所以所有用户都不可以登陆. 解决 ...
- SQL Server中常用的SQL语句(转):
SQL Server中常用的SQL语句 转自:http://www.cnblogs.com/rainman/archive/2013/05/04/3060428.html 1.概述 名词 笛卡尔积.主 ...
- 安装SQL Server时,提示VS Shell 安装失败,退出代码为 1638。
在安装SQL Server时,提示“安装 Microsoft Visual C++ 2015 Redistributable 时出错VS Shell 安装失败,退出代码为 1638”. 原因:是由于你 ...
- SQL Server 2008 R2提示评估期已过
解决SQL Server 2008 r2提示评估期已过 1.注册表把 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\100\Co ...
- 处理SQL Server 异常常用步骤
处理SQL Server 异常常用步骤 SQL Server常见的问题主要是SQL问题造成,常见的主要是CPU过高和阻塞. 一.CPU过高的问题 1.查询系统动态视图查询执行时间长的sql语句 WIT ...
- (4.6)sql server索引缺失提示
SQLSERVER如何查看索引缺失 sql server索引缺失提示 当大家发现数据库查询性能很慢的时候,大家都会想到加索引来优化数据库查询性能, 但是面对一个复杂的SQL语句,找到一个优化的索引组合 ...
- 【随记】安装SQL Server 2008 R2 提示创建usersettings/microsoft.sqlserver.configuration.landingpage.properties.se
在安装SQL Server 2008 R2 提示创建usersettings/microsoft.sqlserver.configuration.landingpage.properties.se.. ...
- SQL SERVER 中的提示
提示是指定的强制选项或策略,由 SQL Server 查询处理器针对 SELECT.INSERT.UPDATE 或 DELETE 语句执行. 提示将覆盖查询优化器可能为查询选择的任何执行计划. 注意: ...
随机推荐
- JVM性能优化简介
01. JVM是什么 概述: 大白话: 全称Java Virtual Machine(Java虚拟机), 它是一个虚构出来的计算机, 通过实际的计算机来模拟 ...
- Redis内存模型(1):内存统计及划分
1. 内存统计 查看命令:info memory 示例: 部分含义: used_memory: Redis分配器分配的内存总量(单位是字节),包括使用的虚拟内存. used_memory_rss: R ...
- Ubuntu拒绝root用户ssh远程登录
sudo vim /etc/ssh/sshd_config 找到并用#注释掉这行:PermitRootLogin prohibit-password 新建一行 添加:PermitRootLogin y ...
- nmap指令
-sP 主机发现 -p 端口扫描(可区域) -sV 端口(服务版本信息)-O 操作系统-iL 使用列表里的IP.(快捷方便)-iR 对公网上的随机n个IP.--excludeile ...
- 逆向破解之160个CrackMe —— 031
CrackMe —— 031 160 CrackMe 是比较适合新手学习逆向破解的CrackMe的一个集合一共160个待逆向破解的程序 CrackMe:它们都是一些公开给别人尝试破解的小程序,制作 c ...
- var定义变量的使用细节
js中定义一个变量可以加关键词var也可以不加,规则是这样的: 1. 在全局范围内用不用var都可以,变量都是全局的 2. 在局部范围内比如函数中,用不用var是不一样的,用v ...
- 用!htrace调试句柄泄漏的一般步骤
Windbg调试器的!htrace扩展对于调试泄漏处理非常方便.该过程基本上可归结为以下简单步骤: 启用跟踪 拍张快照 情景分析 显示差异 在第四步!htrace将在最后一个快照之后显示所有额外打开的 ...
- 神经机器翻译(seq2seq RNN)实现详解
http://c.biancheng.net/view/1947.html seq2seq 是一类特殊的 RNN,在机器翻译.文本自动摘要和语音识别中有着成功的应用.本节中,我们将讨论如何实现神经机器 ...
- Scala词法文法解析器 (一)解析SparkSQL的BNF文法
平台公式及翻译后的SparkSQL 平台公式的样子如下所示: if (XX1_m001[D003]="邢おb7肮α䵵薇" || XX1_m001[H003]<"2& ...
- Eureka比Zookeeper好在哪里?
Eureka遵守AP,Zookeeper遵守CP RDBMS(oracle/mysql.sqlServer) ====> ACID, 关系型数据库遵循ACID原则: NoSQL(redis/mo ...