SQL Server的常用提示
时间:2019-09-17
本文章向大家介绍SQL Server的常用提示,主要包括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提示灵活很多。
原文地址:https://www.cnblogs.com/OpenCoder/p/11532504.html
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解