- 浏览: 2036783 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (651)
- ACE (35)
- BAT (9)
- C/C++ (116)
- fast-cgi (14)
- COM (27)
- python (59)
- CGI (4)
- C# (2)
- VC (84)
- DataBase (29)
- Linux (96)
- P2P (6)
- PHP (15)
- Web (6)
- Memcached (7)
- IME输入法 (11)
- 设计模式 (2)
- 搜索引擎 (1)
- 个人情感 (4)
- 笔试/面试 (3)
- 一亩三分地 (33)
- 历史 (2)
- 地理 (1)
- 人物 (3)
- 经济 (0)
- 不仅仅是笑哦 (43)
- 小故事大道理 (2)
- http://www.bjdsmyysjk120.com/ (0)
- http://www.bjdsmyy120.com/ (0)
- 它山之石可以攻玉 (15)
- 大学生你关注些什么 (28)
- 数据恢复 (1)
最新评论
-
luokaichuang:
这个规范里还是没有让我明白当浏览器上传文件时,STDIN的消息 ...
FastCGI规范 -
effort_fan:
好文章!学习了,谢谢分享!
com技术简介 -
vcell:
有错误os.walk(strPath)返回的已经是全部的文件和 ...
通过python获取目录的大小 -
feifeigd:
feifeigd 写道注意:文章中的CPP示例第二行 #inc ...
ATL入门:利用ATL编写简单的COM组件 -
feifeigd:
注意:文章中的CPP示例第二行 #include " ...
ATL入门:利用ATL编写简单的COM组件
Sql Server 的两类关系型索引:聚集索引和非聚集索引
一、索引的构造
聚集索引:数据实际上是按顺序存储的,就好像参考手册将所有主题按序编制一样。一旦找到了所要搜索的数据,就完成了这次搜索。
非聚集索引:索引完全独立于数据本身结构的。一旦在索引中找到了要寻找的数据,就必须跟随其指针定位到实际的数据。
索引是由具有如下特征的一棵树所组成的,唯一的、作为遍历起点的根分页、可能存在的中间索引层以及底层的叶子分页。使用索引可以找到正确的叶子分页。索引的中间层次数是根据表的行数以及索引行的大小而变化的。
聚集索引和非聚集索引之间的最大区别在于除了索引键以外叶级别还存放了什么。
A、聚集索引:
聚集索引的叶级别不仅包含了索引键,还包含数据页。也就是说数据本身也是聚集索引的一部分。聚集索引基于键值保存表中的数据有序。表中的数据是通过一个被称作页链的双向链接表来维护的。页链中的页顺序以及数据页上的记录顺序就是索引键的顺序。
由于实际的数据页的页链只能按一种方式排序,因此一张表只能拥有一个聚集索引。在许多情况下,查询优化器非常倾向于采用聚集索引,因为聚集索引能够让我们直接在叶级别找到数据。
许多介绍Sql Server索引的文档会这样告诉读者:聚集索引按照 排序顺序物理地存储数据。如果读者认为物理存储就是磁盘本省的话就会产生误解。试想如果聚集索引必须按照特定顺序在实际的磁盘上维护数据的话,那么任何修改操作都将产生产生相当高昂的代价。当一个分页变得很忙并且必须一份为二时,所有后续页面上的数据就都必须向后移动。
聚集索引的排序顺序仅仅表示数据页链在逻辑上是有序的。如果Sql Server跟谁页链的话,就能以聚集索引键的顺序访问到每一行,而当添加新的行的分页时只需在页链中调整链接
Sql Server 2005中,所有的聚集索引都是唯一的。如果在创建聚集索引时没有指定unique关键字,Sql Server会在需要时通过往记录中添加一个唯一标识符在内部保证索引的唯一性。该标识符是一个4字节长的值,作为附加的聚集索引键的字段添加到数据库中。只有那些声明为索引键字段并拥有重复值的行才会被添加。
B、非聚集索引:
对于非聚集索引,叶级别不包含全部的数据。除了键值以外,每个叶级别中的索引行包含了一个书签,告诉Sql Server可以在哪里去找到与索引键相应的数据行。一个书签可能有两种格式:
1)、如果表上有聚集索引,,书签就是相应的数据行的聚集索引键
2)、如果表示堆结构(也就是没有聚集索引的情况),书签就是一个标识符,以”文件号:页号:槽号”的格式来定位实际的行。
二、创建索引
Create [unique] [clustered | nonclustered] Index index_name on table_name(column_name[ASC|DESC])
通过关键字unique可以指定Sql Server必须强制规定索引键值的唯一性。如果不指定UNIQUE,重复的键值就是允许的。还可以指定索引是聚集的或者非聚集的。非聚集索引是默认值
包含性列:
Sql Server2005的索引键字段数量限制是16个,总共900个字节大小,然而sql server2005还允许用户创建带有包含性列的索引
Create [unique] [clustered | nonclustered] Index index_name on table_name(column_name[ASC|DESC])
[include (column_name[,…n]]
包含性列只在页级别中出现而且不以任何方式控制索引行的排序。它们的目的是使叶级别能够包含更多信息从而更大地发挥覆盖索引的索引调优能力。覆盖索引是一种非聚集索引,在其叶级别就可以找到满足查询的全部信息
约束和索引:
在声明主键或者唯一约束时,在表的一个或多个字段上会创建一个唯一性索引,就好像是用了create index命令一样。这些被创建出来以支持约束的索引名称与约束的名称相同。就索引的内部存储及其维护而言,是用create index命令创建的唯一性索引与用来支持约束而自动生成的索引之间没有区别。查询优化器是根据唯一性索引是否存在而不是根据一个字段上是否声明过主键来做决策的。
使用create index命令创建的索引和支持约束所创建的索引之间最大的区别在于该如何删除这个索引。Drop
Index命令只允许用户删除那些通过create index命令所建立的索引。另外,要删除由外键约束引用着的主键或唯一性约束的话,必须先删除外键约束。
关于是否应该使用唯一性约束或主键约束来定义唯一性是一个普遍关注的问题,且经常令人产生混淆
这里需要指明的是:约束是一个逻辑的概念,而索引是一个物理的概念。在建立索引时,实际上是请求Sql Server 创建一个占用存储空间并且在数据修改操作中必须得到维护的物理结构。在定义约束时,实际上是在定义数据的属性并且期望Sql Server强制限制该属性,而不是告诉它该如何强制。Sql Server当前的版本支持通过创建唯一性索引来支持主键和唯一性约束,但这不是产生唯一性索引的必要要求。Sql Server可能会在未来的版本中除了建立索引以外的某些其他方法来强制唯一性,但对于Sql Server20005来说是行不通的。
三、索引的分页结构
索引分页为三个基本类型:非聚集索引的叶级别、聚集索引的节点(非页级)级以及非聚集索引的节点级。对于聚集索引的叶级别,实际上并不存在一种独立的结构,因为那些就是数据分页。
聚集索引的节点行:
聚集索引的节点级包含了指向索引下一级的指针。分页指针的长度为6个字节:文件号占了2个字节,文件中的分页号占了4个字节。
非聚集索引的叶级行:
非聚集索引的叶级别行包含了每个键值以及一个书签。
非聚集索引的节点行:
非聚集索引的非叶级别只能在向较低级别遍历分页时起到作用。如果非聚集索引是唯一性的,那么节点行就只需非聚集索引键以及指向下层分页的指针。如果索引没有定义成唯一性的,即使所有的数值都是唯一的,非叶级索引行仍然包含书签
四、特殊索引
Sql Server 2005允许创建两种特殊类型的索引:1)、在计算列上建索引 2)、在视图上建索引
先决条件:给定相同的基准表数据,任何计算列或者视图中的任何行每次的返回值都是一致的。
1、必须为几个会话级的选项设置特定的数值
Set concat_null_yields_null on
Set quoted_identifier on
Set ansi_nulls on
Set ansi_padding on
Set ansi_warnings on
Set numeric_roundabort off
在创建这类特殊索引之前可以利用属性函数sessionproperty来测试当前连接的设定。返回值为1表示设定值为ON,而0就表示设定值为OFF
Select sessionproperty(‘numeric_roundabort’)
2、列和视图所使用的函数必须为确定性函数
当全部set选项都具有要求的设定值时,如果一个函数总是对相同的输入值返回相同的结果,那么次函数九被认为是确定性函数
3、架构绑定
创建索引视图要求数据表本身的任何基准对象的架构不能改变。为了防止架构定义的改变,create view语句允许使用with schemabinding选项,当指定了with schemabinding以后,定义次试图的select语句必须包含所有引用表的两段式名字
基于计算列的索引
Sql Server 2005允许你在确定的、精确的计算列上创建索引
在计算列上创建索引之前,可以使用IsDeterministic字段属性来判断字段是否具有确定性。如果指定了此属性返回1,否则返回0
索引视图
Sql Server中的索引视图类似于其他产品中的物化视图。索引视图最大的好处之一是具有对大表的累加聚合进行物化的能力。
附加要求:视图的定义也不能包含任何下列元素
1、 top
2、 text、ntext或者image字段
3、 distinct
4、 min、max、count(*)、stdev、variance、avg
5、 可空类型的表达式进行sum
6、 派生表
7、 Rowset函数
8、 其他视图
9、 Union
10、 子查询、outer连接或者自连接
11、 全文索引谓词
12、 Compute 、compute by
13、 Order by
可以使用objectproperty函数的IsIndexable属性来检验是否已经满足了所有需求
Select objectproperty(object_id(‘product_totals’),’IsIndexable’)
创建索引视图
Use Adventureworks
Go
Create view vdiscount1 with schemabinding
As select sum(UnitPrice*OrderQty) as SumPrice,
Sum(UnitPrice*OrderQty*(1.00-UnitProceDiscount)) as SumDiscountPrice,
Count_big(*) as count,
productID
from sales.saleorderdetail
group by productid;
注意上面例子中的with schemabinding字句以及表中指明的架构名称(dbo)
要创建索引视图,必须创建索引。在视图上创建的第一个索引必须是唯一的聚集索引。
组成索引视图的数据是持久化的,因为索引视图将数据保存在聚集索引的叶级别中,Sql Server会自动维护索引视图,只要有任何人修改数据影响到视图,Sql Server就会更新存储在聚集索引中的信息
建立唯一性聚集索引以后,可以在视图上创建多个非聚集索引。用户可以利用objectproperty函数的IsIndexed属性来判断一个 视图是否已经被索引化
Select objectproperty(object_id(‘vdiscount1’,’IsIndexed’))
发表评论
-
Berkeley DB 使用经验总结
2012-08-27 14:41 3087作者:陈磊 NoSQL是现在互联网Web2.0时代备受 ... -
嵌入式数据库系统Berkeley DB
2012-08-27 14:37 1534前言 UNIX/LINUX平台下的数据库种类非常多 ... -
mysql给用户赋予权限
2011-05-20 17:35 1228grant all on *.* to 'apsara' ... -
sqlserver显示数据库和表及列名
2010-05-19 14:59 1627sqlserver显示数据库和表及列名 selec ... -
Browsing Posts tagged freetds
2010-05-14 16:20 1179Browsing Posts tagged freetds ... -
mysql 的注释
2010-05-06 14:22 1264mysql 的注释 谁知道这句话啥意思? /*! ... -
[MySQL优化案例]系列 -- DISABLE/ENABLE KEYS的作用
2010-05-06 14:21 2289[MySQL优化案例]系列 -- ... -
PCRE的安装及使用
2010-04-09 15:46 4198PCRE的安装及使用 Boost太庞 ... -
使用 SELECT
2009-10-15 21:30 1310第一章 SELECT 一、使用SELECT 1、使用S ... -
SQL SERVER 2005 简介
2009-10-15 21:19 2156SQL SERVER 2005 简介 一直以来 ... -
SQL Server 2005报表服务入门(一)
2009-10-15 21:03 8894SQL Server 2005报表服务入门(一) 一、创 ... -
使用 SQL Server 2005中的 CLR 集成
2009-10-14 18:40 1374使用 SQL Server 2005中的 CLR 集成 ... -
SQL SERVER CLR 集成系列之四 创建一个CLR的表值函数---实用的SPLIT函数
2009-10-14 17:21 1615SQL SERVER CLR 集成系列之四 创建一个CLR ... -
SQL SERVER 2005 CLR 集成 之三 关于CONTEXT CONNETION
2009-10-14 17:21 1285SQL SERVER 2005 CLR 集成 之三 关于C ... -
SQL SERVER CLR 集成系列之二 简单的SQL 函数
2009-10-14 17:21 1581SQL SERVER CLR 集成系列之二 简单的SQL ... -
SQL SERVER 2005 CLR集成系列开篇 为什么微软要集成CLR 到SQL SERVER?
2009-10-14 17:20 1298SQL SERVER 2005 CLR集成系列开篇 为什么 ... -
SQL SELECT INTO 语句
2009-10-12 21:12 2681SQL SELECT INTO 语句 SELECT ... -
sql中like语句详解
2009-10-12 21:04 5153sql中like语句详解 确定给定的字符串是否与指 ... -
SqlServer中的dbo是什么意思?
2009-10-12 20:03 13945SqlServer中的dbo是什么意思? DBO是 ... -
SQL Server 2005中各个系统表的作用
2009-10-12 18:57 1544SQL Server 2005中各个系统表的作用 ...
相关推荐
SQL Server 2005 的全文索引是其数据库管理系统中的一个重要特性,它允许用户对存储在text或ntext数据类型的列中的非结构化文本数据进行高效、灵活的搜索。全文索引通过创建一个预处理的索引,使得查询能够快速定位...
在"SQL Server x64"这个文件中,包含的是64位版本的安装程序,安装后你可以创建数据库、设计表结构、编写SQL查询,实现数据的增删改查,以及利用视图、索引、存储过程等功能提高数据处理效率。同时,SQL Server 2005...
SQL Server 2005 Express Edition 是微软推出的一款轻量级数据库管理系统,特别适用于小型企业和个人开发者。在64位(X64)系统上安装SQL Server 2005 Express,可以充分利用更大的内存和处理器资源,从而提高数据...
SQL Server 2005微软官方权威参考书. 公球公认SQL Server 2005 经典著作.. 数据库“铁人”、微软MVP胡百敬先生鼎力推荐 微软SQL Server 总部Principal Group ...第7章 索引的内部构造和管理 第8章 锁定和并发
存储引擎.pdf"将揭示SQL Server 2005的内部工作机制,包括数据存储、索引原理、事务日志管理等核心概念。了解存储引擎的工作原理可以帮助读者优化数据库性能,解决存储和查询效率问题,如合理设计表结构、选择合适的...
### SQL Server 建立索引相关知识点 #### 一、建立索引 索引是在数据库表中的数据列上创建的一种特殊的数据结构,其目的是为了加快数据检索速度。索引类似于书籍的目录,通过索引可以快速定位到所需的数据行,从而...
SQL Server 2005中主要有两种类型的索引:聚集索引(Clustered Index)和非聚集索引(Nonclustered Index)。 1. 聚集索引:决定了数据在磁盘上的物理存储顺序,一个表只能有一个聚集索引。索引键值直接指向数据行...
"SQL Server 索引结构及其使用(聚集索引与非聚集索引)" 数据库索引是数据库性能优化的关键技术之一。SQL Server 提供了两种索引:聚集索引(clustered index)和非聚集索引(nonclustered index)。本文将详细介绍...
SQL Server 2005是微软推出的一款关系型数据库管理系统,具有强大的数据处理能力和高度的可扩展性。这个压缩包包含四本关于SQL Server 2005技术内幕的中文PDF书籍,涵盖了从基础到高级的各个层面,是学习和掌握SQL ...
《SQL Server 2005 数据库系统开发完全手册》是一部深入探讨SQL Server 2005数据库管理系统的重要参考资料,适合数据库开发人员、管理员以及对SQL Server 2005有兴趣的学习者。这本书包含了丰富的实践代码,旨在帮助...
《SQLServer2005.技术内幕四部曲中文PDF》是一套全面解析SQL Server 2005核心技术的中文教程,包含了T-SQL查询、T-SQL程序设计、存储引擎以及查询、调整和优化四个重要方面。这套书籍旨在帮助IT专业人员深入理解SQL ...
"SQL Server 2000 索引结构及使用方法" 本文将详细介绍 SQL Server 2000 的索引结构和使用方法,包括聚集索引和非聚集索引的定义、区别、使用场景和注意事项。 一、索引结构 索引是一种特殊的目录,可以帮助我们...
在SQL Server中,创建索引是一项关键的数据库优化技术,旨在加速数据检索速度,提高查询性能。本文将深入探讨如何在SQL Server中创建索引,包括理解不同类型的索引、索引的创建语法以及如何利用索引提升数据库性能。...
《基于SQL Server 2005学习SQL》 SQL(Structured Query Language)是用于管理和处理关系数据库的标准语言,而SQL Server 2005作为微软公司的一款强大的数据库管理系统,为开发者提供了广泛的功能和工具,使其在...
在SQL Server 2000中,索引是数据库性能优化的关键组成部分,它极大地影响了数据查询的速度。本文将深入探讨SQL Server 2000中的索引优化,旨在帮助数据库管理员和开发人员理解如何有效地利用索引来提升系统性能。 ...
通过这四本书的学习,读者可以系统地了解SQL Server 2005的各个方面,从基本的查询到复杂的存储引擎内部工作原理,再到性能调优和高级编程技术,全面提升对SQL Server 2005的理解和应用能力。由于这些书籍以CHM格式...
本书全面覆盖了存储引擎的工作原理、设计思想以及实际操作中的优化策略,旨在帮助读者深入理解SQL Server 2005的内部机制,提升数据库管理与性能优化的能力。 在T-SQL存储引擎部分,我们可以探讨以下几个关键知识点...
SQL Server全文索引查询是一种在SQL Server数据库中用于高效检索大量文本数据的技术。与传统的基于B树结构的索引不同,全文索引专注于处理“包含”式查询,即查询字符串中是否包含特定的关键词,而不仅仅是以特定...
SQL Server的索引结构及其使用是数据库管理中的关键概念,主要分为聚集索引(Clustered Index)和非聚集索引(Nonclustered Index)。 聚集索引,顾名思义,是表数据按照索引键的顺序物理存储的索引。在SQL Server...
1. **逆向工程**:使用数据库逆向工程工具,将SQL Server 2005的数据库结构转化为脚本,然后手动或自动修改以适应SQL Server 2000的语法。 2. **转换工具**:正如描述中所提及的,使用特定的转换工具,如Database ...