`
jiagou
  • 浏览: 2607380 次
文章分类
社区版块
存档分类
最新评论

SQL Server--索引

 
阅读更多

一,索引的概述

1,概念: 数据库索引是对数据表中一个或多个列的值进行排序的结构,就像一本书的目录一样,索引提供了在行中快速查询特定行的能力.

2,优缺点:

2.1优点: 1,大大加快搜索数据的速度,这是引入索引的主要原因.

2,创建唯一性索引,保证数据库表中每一行数据的唯一性.

3,加速表与表之间的连接,特别是在实现数据的参考完整性方面特别有意义.

4,在使用分组和排序子句进行数据检索时,同样可以减少其使用时间.

2,2缺点: 1,索引需要占用物理空间,聚集索引占的空间更大.

2,创建索引和维护索引需要耗费时间,这种时间会随着数据量的增加而增加.

3,当向一个包含索引的列的数据表中添加或者修改记录时,SQL server 会修改和维护相应的索引,这样增加系统的额外开销,降低处理速度。

3,索引的分类:

1,按存储结构可分为:

a,聚集索引:指物理存储顺序与索引顺序完全相同,它由上下两层组成,上层为索引页,下层为数据页,只有一种排序方式,因此每个表中只能创建一个聚集索引。

b,非聚集索引:指存储的数据顺序一般和表的物理数据的存储结构不同。通过下表我们可以分析出:(其中在学号上建立非聚集索引)

2,根基索引键值是否唯一,可以判定是否为唯一索引;基于多个字段的组合创建索引的为组合索引

二,索引的操作:

1,创建:(1),原则:a,只有表的所有者可以在同一个表中创建索引;

b,每个表中只可以创建一个聚集索引;

c,每个表中最多可以创建249个非聚集索引;

d,在经常查询的字段上建立索引;

e,定义text,image和bit数据类型的裂伤不能创建索引;

f,在外键列上可以创建索引,主键上一定要有索引;

g,在那些重复值比较多的,查询较少的列上不要建立索引。

(2),方法:a,使用SQL server Management Studio创建索引。

b,使用T-SQL语句中的create Index语句创建索引

c,使用Create table或者alter Table语句为表列定义主键约束或者唯一性约束时,会自动创建主键索引和惟一索引。

这里说说T-sql语句创建索引:

语法:

create relational index create[unique][clustered|nonclustered]   index index_name  on<object>(cloumn[asc|desc][,……n])
  [include (column_name[,……n])]
     [with(<relational_index_option>[,……n])]
 [onfilegroup_name] 

说明:1,include (column_name[,……n])指定要添加到非聚集索引的叶级别的非键列。

2,on filegroup_name,为指定文件组创建指定索引。

例如:在course表中,对“课程代号”列创建聚集索引zindex.

use db_student
 create clustered index zindex on course(课程代号)


2,查看索引:(1),使用SQL ServerManagement Studio查看索引信息

(2),使用系统存储过程查询索引信息,用SP_helpindex可以返回表中的所有索引信息

例如:查看course表的索引信息

use db_student
   execsp_helpindex course


3,修改索引:

(1),在SQL Server Management Studio 中修改索引

(2),使用Alter Index语句修改索引

在这里为大家举一个例子:

在course数据表中,修改所有的索引,并指定选项

use db_student
    alterindex all on course rebuild with (fillfactor=80,sort_in_tempdb=on,statistics_norecompute=on)


4,删除索引:

(1),使用SQL Server Management Studio 删除索引

(2),使用Drop index语句删除索引

例如:在course表中,删除zindex索引

use db_student
 drop index course.zindex


三,索引的分析和维护:

分析:1,使用showplan 语句

语法:set showplan_all{on|off},set showplan_next{on|off}

例子:显示表course的课程代号,课程类型,课程内容,并显示查询过程

use db_student
 set showplan_all on  select 课程代号,课程类型 课程内容 from course where 课程内容='loving'


2,使用statistics io语句

语法:statistics io{on|off} on和off分别为显示和不显示,使用方法和上一样。

维护: 1,使用dbcc showcontig语句,显示指定表的数据和索引的碎片信息。当对表中进行大量修改或添加数据后,应该执行此语句查看有无碎片。

语法:dbcc showcontig[{table_name|table_id|view_name|view_id},index_name|index_id] with fast

2,使用dbcc dbreindex语句,意思是重建数据库中表的一个或多个索引。

语法:

dbcc dbreindex
 (['database.owner.table_name'[,index_name[,fillfactor]]])  [withno_infomsgs]

说明: database.owner.table_name,重新建立索引的表名

index_name,是要重建的索引名

fillfactor,要创建索引时每个索引页上要用于存储数据的空间百分比。

with no_infomsgs,禁止显示所有信息性消息

3,使用dbcc indexdefrag,整理指定的表或视图的聚集索引和辅助索引碎片。

语法:

dbcc  indexdefrag
   ({database_name|database_id|0},{table_name|table_id|'view_name'|view_id},{index_name|index_id}) 
  with no_infomsgs                  


总结,只有我们对索引有了充分了熟悉;我们掌握了索引的增删改查四项基本操作,学会利用SQL Server ManagerSdudio去实现这些功能,和学会利用T-SQL语句去实现(自我感觉利用SQL Server Manager Sdudio 简单一些);当然还要懂得学会分析和维护索引,这样才会更好的让它为咱们服务!

分享到:
评论

相关推荐

    SQL SERVER-2008从入门到精通.pdf

    《SQL SERVER 2008从入门到精通》是一本专为初学者和进阶者设计的教程,全面覆盖了SQL Server 2008的各项核心功能和实用技术。SQL Server是微软公司推出的一种关系型数据库管理系统,广泛应用于数据存储、分析和报表...

    SqlServer-查看所有表、行数、索引名称、索引的字段

    系统跑久了,对于所有的索引想做一个具体的确认,所以写了这么一段, 可以用来分析自己数据的表及索引详情 针对记录数比较大的表,尤其要注意索引的情况,非常影响性能

    SQLServer2016-SSEI-Expr.rar

    《SQL Server 2016:企业级数据库管理和商业智能的基石》 SQL Server 2016是Microsoft推出的一款强大的关系型数据库管理系统,它在数据存储、处理和分析领域扮演着至关重要的角色。作为微软数据库家族的重要成员,...

    SQL2022-SSEI-Dev.rar

    8. **性能调优**:涉及索引优化、查询改写、资源监控和SQL Server Profiler的使用。 9. **安全性**:包括用户权限管理、角色、登录、防火墙规则以及SSEI(假设的服务器端加密)。 10. **备份与恢复**:确保数据...

    cn-sql-server-2012-express-sqlexpr-x64

    SQL Server 2012是微软推出的一款关系型数据库管理系统,而Express版是其免费且轻量级的版本,适合个人学习、小型应用以及开发测试环境。 描述 "cn_sql_server_2012_express_sqlexpr_x64" 更进一步确认了这是针对...

    SQLServer--关系数据库系统管理与开发(2)

    《SQLServer--关系数据库系统管理与开发(2)》这一资料主要聚焦于SQL Server这一关系数据库管理系统在管理和开发中的深入探讨。SQL Server是Microsoft公司推出的一款强大的数据存储、处理和分析平台,它广泛应用于...

    Geoserver sqlServer插件

    `Geoserver sqlServer插件`是专门为GeoServer设计的,目的是使其能够与Microsoft SQL Server数据库进行交互,读取、写入和管理其中的地理空间数据。这个插件使得GeoServer能够识别和处理SQL Server中存储的几何对象...

    SQL SERVER-2008从入门到精通pdf

    11. **性能调优**:监控和优化SQL Server的性能,包括查询优化、索引调整、内存管理、查询计划等。 通过这个全面的教程,你将掌握SQL Server 2008的基本操作和高级特性,从而能够有效地管理和利用数据库资源,提升...

    sql-server-2016-samples,SQL SERVER 2016 脚本例子

    在SQL Server 2016中,数据库管理系统(DBMS)提供了一系列强大的功能,使得数据管理、查询和分析更为高效。这个"sql-server-2016-samples"压缩包包含的是针对SQL Server 2016的一系列示例脚本,是学习和理解SQL ...

    SQL SERVER-2008从入门到精通

    《SQL SERVER-2008从入门到精通》是一本由Mike Hotek编著的电子书,主要针对SQL Server 2008这一数据库管理系统,旨在帮助初学者快速掌握SQL Server的基本操作和高级技巧,逐步成长为数据库管理的专业人士。SQL ...

    SQL server-2017-学习笔记.docx

    在SQL Server 2017的学习中,我们首先需要了解SQL Server的基础操作,这包括了基本的增删改查操作,比如INSERT、DELETE、UPDATE和SELECT。这些是数据库管理中最常用的操作,用于处理数据的存取和修改。 接着,我们...

    sql-optimizer-for-sql-server_1001官方试用版+安装手册+使用教程

    《SQL优化器 for SQL Server 1001:官方试用版详解及使用指南》 在数据库管理领域,SQL优化是提升系统性能的关键步骤。本文将深入探讨"SQL优化器 for SQL Server 1001"这一专业工具,旨在帮助用户理解和掌握其功能...

    记录SQL server的代码sql-server-master.zip

    2. **数据库对象**:SQL Server中的主要对象包括表、视图、索引、存储过程、触发器、函数等。表是数据存储的基本单元,视图是从一个或多个表中导出的数据集合,索引可以加速查询速度,存储过程和函数则为复杂的业务...

    sql-server-for-2014.rar_SQL Server 2014_sql server

    6. **Columnstore索引**:在SQL Server 2014中,列存储索引得到增强,支持实时分析和在线查询,极大地提高了数据仓库的查询性能。 7. **Stretch Database**:这是一个新特性,允许将冷数据自动移动到Azure,从而...

    Inside Microsoft SQL Server 2008 T-SQL Programming.pdf

    ### 关于《Inside Microsoft SQL Server 2008 T-SQL Programming》的知识点解析 #### 一、SQL Server 2008概述 《Inside Microsoft SQL Server 2008 T-SQL Programming》这本书深入地介绍了SQL Server 2008的各项...

    SQL-Server-DBA.rar_sql server

    《SQL Server DBA 最新问题解析》 在IT领域,SQL Server数据库管理员(DBA)的角色至关重要,他们负责确保数据库的高效运行、安全性和可靠性。本资料“SQL-Server-DBA.rar”聚焦于SQL Server数据库管理的最新问题,...

    SQL优化-索引(1-15).rar

    综上所述,这个压缩包文件提供了全面的SQL Server索引优化知识,包括索引的类型、创建、维护、选择性、覆盖率以及在并发环境下的应用。学习这些内容将有助于提升SQL查询的性能,为数据库系统的高效运行打下坚实基础...

    SQL Server 索引结构及其使用(聚集索引与非聚集索引)

    "SQL Server 索引结构及其使用(聚集索引与非聚集索引)" 数据库索引是数据库性能优化的关键技术之一。SQL Server 提供了两种索引:聚集索引(clustered index)和非聚集索引(nonclustered index)。本文将详细介绍...

    Inside Microsoft SQL Server 2008 T-SQL Programming

    《Inside Microsoft SQL Server 2008 T-SQL Programming》这本书深入探讨了SQL Server 2008中的T-SQL编程技术,这是SQL Server数据库管理与开发的核心语言。T-SQL,即Transact-SQL,是SQL的一个扩展,主要用于微软的...

Global site tag (gtag.js) - Google Analytics