广告
返回顶部
首页 > 资讯 > 数据库 >SQLserver 数据库的索引,存储过程和触发器的使用与概念
  • 196
分享到

SQLserver 数据库的索引,存储过程和触发器的使用与概念

2024-04-02 19:04:59 196人浏览 八月长安
摘要

前言:索引,存储过程和触发器可以对一些高级的数据处理和查询,从而更好的实现对数据库的操作,诊断和优化。一.索引 索引提供指针以指向存储在表中指定的数据值,数据库的索引,就好比一本书中的目录类似,无

前言:索引,存储过程和触发器可以对一些高级的数据处理和查询,从而更好的实现对数据库的操作,诊断和优化


一.索引

 索引提供指针以指向存储在表中指定的数据值,数据库的索引,就好比一本书中的目录类似,无需阅读整个一本书,利用目录就可以快速的查找所需信息。在数据库中,索引使数据库程序无需对整个表进行扫描,就可以在其中找到所需数据。通过使用索引,可以大大提高数据库的查询速度

 (1) 索引分类

   1.唯一索引

   唯一索引不允许两行具有相同索引值

   2.主键索引

   在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型

   3.聚集索引

   在聚集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同

   4.非聚集索引

   非聚集索引建立在索引页上,在查询数据时可以从索引中找到记录存放位置

   5.复合索引

   在创建索引时,并不是只能对其中一列创建索引,与创建主键一样,可以将多个列组合作为索引,这种索引称为复合索引

 

 (2)创建和使用索引


1、首先创建一个数据量大的表,名称为“学生表”,分别有三列,学号,姓名和班级,如下图所示,学号为自动编号,班级为默认值“一班”。

SQLserver 数据库的索引,存储过程和触发器的使用与概念


2、向表中插入大量数据,数据越多,验证索引的效果越好。

使用语句完成:While 1>0  Insert into t388(姓名)  values(‘小明’)

上面语句是一个死循环,除非强制结束,如果1大于0就会一直向表中插入姓名

如下图所示:


SQLserver 数据库的索引,存储过程和触发器的使用与概念

3,等待5分钟左右,打开表的属性,查看表的行数,当前为1,如下图所示:713179


SQLserver 数据库的索引,存储过程和触发器的使用与概念


4,使用语句查询第600000行的数据,Select * from t388 Where 学号=600000

SQLserver 数据库的索引,存储过程和触发器的使用与概念


5、打开“SQL Server profiler ”工具进行跟踪,如下图所示:

打开“sql server profiler ”工具查看跟踪的信息,发现查询时间很长,cpu工作了188毫秒,reads:读了6614次,writes:写了9次,duration:总计花费2977毫秒完成查询。

SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念


6,开始创建索引(唯一索引)

SQLserver 数据库的索引,存储过程和触发器的使用与概念

SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念


点击确定,完成创建,再次使用语句查询第600020行的数据,Select * from t388 Where 学号=600020

SQLserver 数据库的索引,存储过程和触发器的使用与概念

这是唯一索引创建。主键索引不用创建,把列设置为表的主键,自动生成主键索引

SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念



二,存储类型

  

   (1) 存储过程是sql语句和控制语句的预编译集合,保存在数据库中,可由应用程序执行,而且允许用户声明变量,逻辑控制语句和强大的编程功能

    使用存储过程的好处:

        1.模块化程序设计

      2.执行速度快,效率高

      3.减少网络流量

      4.具有很好的安全

   (2)系统存储过程

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

           常用的系统存储过程

           sp_database 列出服务器上的所有数据库的信息,包括数据库名和数据大小

           sp_helpdb 报告有关指定数据库或所有数据库的信息

           sp_renamedb 更改数据库的名称

           sp_tables 返回当前环境下可查询的表和视图的信息

           sp_columns 返回某个表和视图的列信息,包括列的数据类型和长度等

           sp_help 查看某个数据库对象的信息:如列名,主键,约束,外键,索引等

           sp_helpconstraint 查看某个表的索引

           sp_stored_procedures 显示存储过程的列表

           sp_passWord 添加或修改登录账户的密码

           sp_helptext 显示默认值,未加密的存储过程,用户定义的存储过程,触发器或视图的实际文本

 

            使用T-SQL语句调用执行存储过程的语法如下:

             EXEC 存储过程名 [参数值]

                 其中EXEC时execute的简写


    (3)使用系统存储过程,以查询数据库大小的 sp_database 为例,以上的都是以下格式来执行

    SQLserver 数据库的索引,存储过程和触发器的使用与概念

 (4)扩展存储过程

    语法:EXEC xp_cmdshell DOS命令 {no_output}


    若xp_cmdshell作为服务器安全配置的一部分而被关闭,请用以下语句开启:

       

   

   exec sp_configure 'show advanced options',1  --显示高级配置信息

   Go 

   reconfigure   --重新配置

   go

    exec sp_configure 'xp_cmdshell',1

   go

   reconfigure   -- 重新配置

   go

SQLserver 数据库的索引,存储过程和触发器的使用与概念


以在C盘创建一个bene的文件夹为例

exec xp_cmdshell 'mkdir c:\bene',no_output

 SQLserver 数据库的索引,存储过程和触发器的使用与概念

SQLserver 数据库的索引,存储过程和触发器的使用与概念

 

(5)自定义存储过程

          在sql-server中,用于创建处处过程的sql语句为create procedure,所有的存储过程都存放在当前数据库中。一个完整的存储过程都包含以下三        部分

          1.输入参数和输出参数

          2.在存储过程中执行的T-SQL语句

          3.存储过程的返回值

   自定义存储过程

   以编写求网络管理平均分存储过程为例

IF EXISTS(SELECT * FROM SYSOBJECTS WHERE name = 'usp_GetAverageResult') 

DROP PROCEDURE usp_GetAverageResult

GO

CREATE PROCEDURE usp_GetAverageResult

AS

DECLARE @subJectID nvarchar(4)

SELECT @subJectID=subJectID FROM dbo.TSubject WHERE subJectName='网络管理'

DECLARE @avg decimal (18,2)

SELECT @avg=avg(mark) from dbo.TScore where subJectID=@subJectID

PRINT '网络管理专业平均分是:'+CONVERT(VARCHAR(5),@avg)

go

SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念

SQLserver 数据库的索引,存储过程和触发器的使用与概念

上述代码主要理解创建存储过程的语法,其中涉及的变量及判断语句等无需深究,只要能根据语句理解就可,有兴趣可以查看资料自学



三,触发器

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

  (1)触发器类型
        INSERT触发器:当向表中插入数据是触发,自动执行所定义语句

        UPDATE触发器:当更新表中某列,多列时触发,自动执行所定义语句

        DELETE触发器:当删除表时触发,自动执行所定义语句


 (2)创建触发器

       使用T-SQL语句创建

语句:CREATE TRIGGER [触发器名称]

      ON [需要创建触发器的表]

     FOR ([DELETE,INSERT,UPDATE)

     AS SQL 语句

      以当有人试图在表中更改数据时,将提示一条消息并阻止操作为例,以下语句可实现:

create trigger reminder --定义触发器名称为“reminder”

on dbo.TScore --在哪个表执行,此例在“dbo.Tscore”表中

for UPDATE --指定在表中执行那些数据修改语句时激活触发器,可以指定多个,用,分隔。此例为“UPDATE”

as

print '禁止修改,请联系DBA'   --触发时显示的文字

ROLLBACK TRANSACTION

GO

SQLserver 数据库的索引,存储过程和触发器的使用与概念SQLserver 数据库的索引,存储过程和触发器的使用与概念



您可能感兴趣的文档:

--结束END--

本文标题: SQLserver 数据库的索引,存储过程和触发器的使用与概念

本文链接: https://www.lsjlt.com/news/41848.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作