SQL Server查询优化与事务处理

博文目录
1、索引
2、视图
3、存储过程
4、系统存储过程
5、触发器
6、事务
7、锁shell

1、索引

索引提供指针以指向存储在表中指定列的数据值,而后根据指定的次序排列这些指针,再跟随指针到达包含该值的列。数据库

一、什么是索引

数据库中的索引与书籍中的目录类似。在一本书中,无需阅读整本书,利用目录就能够快速的查找到所需的信息。在数据库中,索引使数据库程序无须对整个表进行扫描,就能够在其中找到所需的数据。书中的目录就是一个词语列表,其中注明了包含各个词的页码。而数据库中的索引是某个表中一列或若干列值的集合,以及物理表示这些值得数据业的逻辑指针清单。编程

索引是SQL Server编排数据的内部方法,它为SQL Server提供一种方法来编排查询数据的路由。安全

索引页是数据库中存储索引的数据页。索引页存放检索数据行的关键字页以及该数据行的地址指针。经过使用索引,能够大大提升数据库的检索速度,改善数据库性能。服务器

二、索引分类

1)惟一索引

惟一索引不容许两行具备相同的索引值。
若是现有数据中存在重复的键值,则通常状况下大多数数据库不容许建立惟一索引。当新数据使表中的键值重复时,数据库也拒绝接收此数据。建立了惟一约束,将自动建立惟一索引。尽管惟一索引有助于找到信息,可是为了得到最佳性能,建议使用主键约束。网络

2)主键索引

在数据库关系图中为表定义一个主键将自动建立主键索引,主键索引是惟一索引的特殊类型。
主建索引要求主键中的每一个值都是惟一的。当在查询使用主键索引时,它还容许快速访问数据。并发

3)汇集索引

在汇集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同。一个表中只能包含一个汇集索引。编程语言

4)非汇集索引

非汇集索引创建在索引页上,在查询数据是能够从索引中找到记录存放的位置。
非汇集索引使表中各行数据存放的物理顺序与键值的逻辑顺序不匹配。汇集索引比非汇集索引有更快的数据访问速度。在SQL Server中,一个表只能建立一个汇集索引,但能够有多个非汇集索引。设置某列为主键,该列就默认为汇集索引。ide

5)复合索引

在建立索引时,并非只能对其中一列建立索引,与建立主键同样,能够将多个列组合做为索引,这种索引称为复合索引。
须要注意的是:只有用到复合索引的第一列或整个复合索引列做为条件完成数据查询时才会用到该索引。模块化

6)全文索引

全文索引是一种特殊类型的基于标记的功能性索引,由SQL Server中全文引擎服务建立和维护。
全文索引主要用于在大量文本中搜索字符串,此时使用全文索引的效率将大大高于使用T-SQL的LIKE关键字的效率。由于全文索引的建立过程与其余类型的索引有很大的差异。

三、建立和使用索引

建立索引的方法有两种:使用SSMS和T-SQL语句。

使用SSMS建立索引,以下:

1)products表中的名称列建立索引

SQL Server查询优化与事务处理

2)右击名称,单击索引/键

SQL Server查询优化与事务处理

3)添加索引,名字为IX_name,单击关闭保存表便可

SQL Server查询优化与事务处理

4)使用索引建立查询

select * from products with (index=IX_name) where 名称='黄瓜';

SQL Server查询优化与事务处理
虽然能够指定SQL Server按哪一个索引进行数据查询,但通常不须要人工指定。SQL Server将会根据所建立的索引,自动优化查询。

使用索引可加快数据检索速度,但为每一个列都创建索引没有必要。由于索引自己也是须要维护,并占用必定的资源,能够按照如下标准选择创建索引的列。

  • 频繁搜索的列;

  • 常常用于查询选择的列;

  • 常常排序、分组的列;

  • 常常用于链接的列(主键/外键);

不要使用下面的列建立索引:

  • 仅包含几个不一样值的列;

  • 表中仅包含几行;

2、视图

视图是保存在数据库中的select查询。所以,对查询指定的大多数操做也能够在视图上进行。使用视图的缘由有两个,其一是处于安全考虑,用户没必要看到整个数据库结构,而隐藏部分数据;其二是符合用户平常业务逻辑,使其对数据更容易理解。

一、什么是视图

视图是另外一种查看数据库中一个或多个表中的数据的方法。视图是一种虚拟表,一般是做为来自一个或多个表的行或列的子集建立的。固然,视图也能够包含所有的行和列。可是,视图并非数据库中存储的数据值的集合,它的行和列来自查询中引用的表。在执行时,视图直接显示来自表中的数据。

视图充当着查询中指定的表的筛选器。定义视图的查询能够基于一个或多个表,也能够基于其余视图、当前数据库或其余数据库。

以下图所示,以表T和表T1为例,该视图能够包含这些表中的所有列或选定的部分列。以下图所示为一个用表T的A列和B列及表T1的B一、C1和D1列建立的视图:
SQL Server查询优化与事务处理

视图一般用来进行如下三种操做:

  • 筛选表中的行;

  • 防止未经许可的用户访问敏感的信息;

  • 将多个物理数据表抽象为一个逻辑数据表;

1)使用视图带来的好处

对最终用户的好处:

  • 结果更容易理解;
  • 得到数据更容易;

对开发人员的好处:

  • 限制数据检索更容易;
  • 维护应用程序更方便;

二、建立和使用视图

1)建立视图

在SQL Server中,建立视图的方法有两种:使用SSMS和使用T-SQL语句。

①展开数据库test,如图所示,右击“视图”,在弹出的快捷菜单中选择“新建视图”命令(自行建立多个表插入数据)
SQL Server查询优化与事务处理

②将A、B、C三张表添加出来
SQL Server查询优化与事务处理

③选择但愿看到列:学员名称、学员年龄、成绩,而后中下方自动生成T-SQL语句,按“crtl+R”快捷键执行语句
SQL Server查询优化与事务处理

④选择T-SQL语句按“crtl+R”快捷键执行便可
SQL Server查询优化与事务处理

2)使用视图的注意事项

  • 每一个视图可使用多个表;

  • 与查询类似,一个视图能够嵌套另外一个视图,最好不要超过三层;

  • 视图定义中的select语句不能包含如下内容:
    order by子句,除非子啊select语句的选择列表中也有一个TOP子句;
    into关键字;
    引用临时表或表变量;

3、存储过程

SQL Server使用存储过程来避免远程发送并执行SQL代码带来的安全隐患。

一、为何须要存储过程

当今的软件大多应用于网络中,而通常应用程序所运用的数据保存在数据库中。在没有使用存储过程的数据库应用程序中,用户大多从本地极端及客户端经过网络向服务器端发送SQL代码编写的请求,服务器端对接收到SQL代码进行语法编译后执行,并经指定结果传送回客户端,再由客户端的应用软件处理后输出。若是开发者对服务器的安全性考虑不全面,就会为非法者提供盗取数据的机会。以下图所示:
SQL Server查询优化与事务处理
未经受权的非法者在网络中截取用户想服务器发送的SQL代码,改写后的恶意SQL代码提交到服务器编译并执行,最后非法者就比较容易地得到他所需的数据。

从图中,咱们能够看到应用程序执行的过程是不安全的,主要在于如下几个方面:

  • 数据不安全:网络传送SQL代码,容易被未经受权者截取;

  • 每次提交SQL代码都要通过语法编译后再执行,影响应用程序的运行性能;

  • 网络流量大。对于反复执行的相同SQL代码,将会在网络上屡次传送,增长网络传输流量;

为了解决这些问题,咱们能够采用存储过程把对数据库操做的SQL代码预先编译好并保存在服务器端,用户只需在本机上输入要执行的存储过程名称和必要的数据就能够直接调用执行存储过程完成行管的操做。这样。既减小了网络传输流量,又能保证应用程序的运行性能,同时也防止了未经受权者想截获SQL代码的行为。

二、什么是存储过程

存储过程是SQL语句和控制语句的预编译集合,保存在数据库中,可由应用程序调用执行,并且容许用户声明变量,逻辑控制语句及其余强大的编程功能。

存储过程可包含逻辑控制语句和数据操做语句,能够接收参数、输出参数、返回单个或多个结果集及返回值。

1)使用存储过程的优势:

存储过程的优势以下:

  • 模块化程序设计;

  • 执行速度快、效率高;

  • 减小网络流量;

  • 具备良好的安全性;

2)存储过程分为如下两类

  • 系统存储过程;
  • 用户自定义的存储过程;

4、系统存储过程

SQL Server提供系统存储过程,它们是一组预编译的T-SQL语句。系统存储过程提供了管理数据库和更新表的机制,并充当从系统表中检索信息的快捷方式。

经过配置SQL Server,能够生成对象、用户、权限的信息和定义,这些信息和定义存储在系统表中。每一个数据库分别有一个包含配置信息的系统表集,用户数据库的系统表是在建立数据库时自动建立的,用户能够经过系统存储过程访问和更新系统表。

一、经常使用的系统存储过程

SQL Server的系统存储过程的名称以“sp-”开头,并存放在Resource数据库中。系统管理员拥有这些存储过程的使用权限。能够在任何数据库中运行系统存储过程,但执行的结果会反映在当前数据库中。
SQL Server查询优化与事务处理

示例以下:

<!--显示数据库-->
exec sp_databases;
<!--显示某个数据库对象的信息-->
exec sp_help A;
<!--显示全部数据库的信息-->
exec sp_helpdb;
<!--更改数据库名字-->
exec sp_renamedb 'xsh','benet';
<!--显示products表的约束-->
exec sp_helpconstraint products;
<!--显示products表的索引-->
exec sp_helpindex products;

上面示例的输出结果集较多,在此不一一列举,请自行逐句运行,查看相应的输出结果。

二、经常使用的扩展存储过程

根据系统存储过程的不一样做用,系统存储过程能够分为不一样类。扩展存储过程是SQL Server提供的各种系统存储过程当中的一类。

扩展存储过程容许使用其余编程语言(如 C##语言)建立外部存储过程,为数据库用户提供从SQL Server实例到外部程序的接口,以便进行各类维护活动。它一般以“xp_”开头,以DLL形式单独存在。

一个经常使用的扩展存储过程为xp_cmdshell,它能够完成DOS命令下的一些操做,如建立文件夹、列出文件夹列表等,其语法以下:
开启系统cmdshell功能

<!--开启系统cmdshell功能-->
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'xp_cmdshell',1
reconfigure;
<!--建立目录-->
exec xp_cmdshell 'mkdir D:\test', no_output;

SQL Server查询优化与事务处理

<!--显示建立目录-->
exec xp_cmdshell 'dir d:\';

SQL Server查询优化与事务处理

5、触发器

触发器是一种特殊类型的存储过程,当表中的数据发生更新时将自动调用,以响应INSERT、UPDATE或DELETE语句。

一、什么是触发器

1)触发器的概念

触发器是在对表进行插入、更新或删除操做时自动执行的存储过程。触发器一般用于强制业务规则,是一种高级约束,能够定义比用CHECK约束更为复杂的约束,能够行发杂的SQL语句(如IF/WHILE/CASE),可引用其余表中的列。触发器主要是经过事件进行触发而被执行的,而存储过程能够经过存储过程名称而被直接调用。当对某一表进行修改,,如UPDATE、INSERT和DELETE这些操做时,SQL Server会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合由这些SQL语句所定义的规则。由此触发器可分为如下几种:

  • INSERT触发器:当向表中插入数据时触发,自动执行触发器定义的SQL语句;
  • UPDATE触发器:当更新表中某列、多列时触发,自动执行触发器所定义的SQL语句;
  • DELETE触发器:当删除表中记录时触发,自动执行触发器定义的SQL语句。

2)deleted表和insertd表

SQL Server查询优化与事务处理

二、触发器的做用

触发器的主要做用是,实现由主键和外键所不能保证的复杂的参照完整性和数据的一致性。

三、触发器的功能

  • 强化约束;
  • 跟踪变化;
  • 级联运行;

四、如何建立触发器

使用T-SQL语句建立触发器的语法以下:

CREATE TRIGGER trigger_name
ON table_name
        [WITH ENCRYPTION]
        FOR { [DELETE, INSERT, UPDATE] }
            AS SQL语句

SQL Server查询优化与事务处理

建立触发器时须要注意如下问题:

  • CREATE TRIGGER必须是批处理中的第一条语句,而且只能应用到一个表中;

  • 触发器只能在当前的数据库中建立,不过触发器能够引用当前数据库的外部对象;

  • 在同一条CREATE TRIGGER语句中,能够为多种用户操做(如INSERT和UPDATE)定义相同的触发器操做;

6、事务

一、什么是事务

事务是一种机制、一个操做序列,包含了一组数据库操做命令,而且把全部的命令做为一个总体一块儿向系统提交或撤销操做请求,即这一组数据库命令要么都执行,要么都不执行。所以,事务是一个不可分隔的工做逻辑单元,在数据库系统上执行并发操做时,事务是做为最小的控制单元来使用的,它特别适用于多用户同时操做的数据库系统。

事务是做为单个逻辑工做单元执行的一系列操做。一个逻辑工做单元必须有四个属性,即原子性、一致性、隔离性及持久性,这些特性一般简称为ACID。

1)原子性

事务是一个完整的操做。事务的各元素是不可分的(原子的)。事务中的全部元素必须做为一个总体提交或回滚。若是事务中的任何元素失败、则整个事务将失败。

2)一致性

当事务完成时,数据必须处于一致状态。也就是说,在事务开始以前,数据库中存储的数据处于一致状态。在正在进行的事务中,数据可能处于不一致的状态,如数据可能有部分修改。然而,当事务成功完成时,数据必须再次回到已知的一致状态。经过事务对数据所作的修改不能损坏数据,或者说事务不能使数据存储处于不稳定的状态。

3)隔离性

对数据进行修改的全部并发事务使彼此隔离的,这代表事务必须是独立的,它不该以任何方式依赖于或影响其余事务。修改数据的事务能够在另外一个使用相同数据的事务开始以前访问这些数据,或者在另外一个使用相同的数据,则直到该事务成功提交以后,对数据的修改才能生效。

4)持久性

事务的持久性指无论系统是否发生了故障,事务处理的结果都是永久的。

二、执行事务的语法

1)开始事务语法以下:

BEGIN TRANSACTION

2)提交事务语法以下:

COMMIT TRANSACTION

3)回滚(撤销)事务语法以下:

ROLLBACK TRANSACTION

BEGIN TRANSACTION语句后面的SQL语句对数据库的更新操做都将记录在事务日志中,直至遇到ROLLBACK TRANSACTION语句或COMMIT TRANSACTION语句。若是事务中某一操做失败且执行ROLLBACK TRANSACTION语句,那么在BEGIN TRANSACTION语句以后全部更新的数据都能回滚到事务开始前的状态。若是事务中的全部操做都所有正确完成,而且使用COMMIT TRANSACTION语句向数据库提交更新数据,那么这时候的数据又处在新的一致状态。

7、锁

一、什么是锁

多个用户可以同时操纵同一个数据库中的数据,会发生数据不一致现象。也就是说,若是没有锁定且多个用户同时访问一个数据库,则当事务同时使用相同的数据时可能会发生问题。这些问题包括丢失、更新、脏读、不可重复读和幻觉读。数据库加锁就是为了解决以上的问题。

二、锁的模式

  • 共享锁(S锁):用于读取资源所加的锁;

  • 排他锁(X锁):和其余任何锁都不兼容,包括其余排他锁,排他锁用于数据修改;

  • 更新锁(U锁):U锁能够看做S锁和X锁的结合,用于更新数据,更新数据时首先须要找到被更新的数据,此时能够理解为被查找的数据上了S锁。当找到须要修改的数据时,须要对被修改的资源上X锁。SQL Server经过U锁来避免死锁问题;

三、查看锁的方法

  • 使用sys.dm_tran_locks动态管理视图;

  • 使用profiler来捕捉锁信息;

四、死锁造成的条件

死锁的本质是一种僵持状态,是由多个主体对资源的争用而致使的。要理解SQL Server中的死锁,能够参考以下图:
SQL Server查询优化与事务处理

发生死锁须要以下四个必要条件:

  • 互斥条件;

  • 请求和等待条件;

  • 不剥夺条件;

  • 环路等待条件;

五、预防死锁

预防死锁就是破坏四个必要条件中的某一个和几个,使其不能造成死锁,经常使用方法以下:

  • 破坏互斥条件;

  • 破坏请求和等待条件;

  • 破坏不剥夺条件;

———————— 本文至此结束,感谢阅读 ————————

相关文章
相关标签/搜索