- 浏览: 127208 次
- 性别:
- 来自: 苏州
文章分类
最新评论
-
miniduan:
i here by provide one that work ...
python 文件插入第一行 -
miniduan:
验证了一下,不好用啊:import fileinput, os ...
python 文件插入第一行
什么是索引
拿汉语字典的目录页(索引)打比方 : 正如汉语字典中的汉字按页存放一样, SQL Server 中的数据记录也是按页存放的,每页容量一般为 4K 。为了加快查找的速度,汉语字(词)典一般都有按拼音、笔画、偏旁部首等排序的目录(索引),我们可以选择按拼音或笔画查找方式,快速查找到需要的字(词)。
同理, SQL Server 允许用户在表中创建索引,指定按某列预先排序,从而大大提高查询速度。
• SQL Server 中的数据也是按页( 4KB )存放
• 索引:是 SQL Server 编排数据的内部方法。它为 SQL Server 提供一种方法来编排查询数据 。
• 索引页:数据库中存储索引的数据页;索引页类似于汉语字(词)典中按拼音或笔画排序的目录页。
• 索引的作用:通过使用索引,可以大大提高数据库的检索速度,改善数据库性能。
索引类型
• 唯一索引 :唯一索引不允许两行具有相同的索引值
• 主键索引 :为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的,并且不能为空
• 聚集索引 (Clustered ) :表中各行的物理顺序与键值的逻辑(索引)顺序相同,每个表只能有一个
• 非聚集索引 (Non-clustered ) :非聚集索引指定表的逻辑顺序。数据存储在一个位置,索引存储在另一个位置,索引中包含指向数据存储位置的指针。可以有多个,小于 249 个
索引类型:再次用汉语字典打比方,希望大家能够明白聚集索引和非聚集索引这两个概念。
唯一索引:
唯一索引不允许两行具有相同的索引值。
如果现有数据中存在重复的键值,则大多数数据库都不允许将新创建的唯一索引与表一起保存。当新数据将使表中的键值重复时,数据库也拒绝接受此数据。例如,如果在 stuInfo 表中的学员员身份证号 (stuID) 列上创建了唯一索引,则所有学员的身份证号不能重复。
提示:创建了唯一约束,将自动创建唯一索引。尽管唯一索引有助于找到信息,但为了获得最佳性能,建议使用主键约束或唯一约束。
主键索引:
在数据库关系图中为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。
聚集索引( clustered index )
在聚集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同。表只能包含一个聚集索引。例如:汉语字(词)典默认按拼音排序编排字典中的每页页码。拼音字母 a , b , c , d……x , y , z 就是索引的逻辑顺序,而页码 1 , 2 , 3…… 就是物理顺序。默认按拼音排序的字典,其索引顺序和逻辑顺序是一致的。即拼音顺序较后的字(词)对应的页码也较大。如拼音 “ha” 对应的字 ( 词 ) 页码就比拼音 “ba” 对应的字 ( 词 ) 页码靠后。
非聚集索引 (Non-clustered )
如果不是聚集索引,表中各行的物理顺序与键值的逻辑顺序不匹配。聚集索引比非聚集索引( nonclustered index )有更快的数据访问速度。例如,按笔画排序的索引就是非聚集索引, “1” 画的字(词)对应的页码可能比 “3” 画的字(词)对应的页码大(靠后)。
提示: SQL Server 中,一个表只能创建 1 个聚集索引,多个非聚集索引。设置某列为主键,该列就默认为聚集索引
如何创建索引
使用 T-SQL 语句创建索引的语法:
CREATE [UNIQUE] [CLUSTERED|NONCLUSTERED]
INDEX index_name
ON table_name (column_name…)
[WITH FILLFACTOR=x]
q UNIQUE 表示唯一索引,可选
q CLUSTERED 、 NONCLUSTERED 表示聚集索引还是非聚集索引,可选
q FILLFACTOR 表示填充因子,指定一个 0 到 100 之间的值,该值指示索引页填满的空间所占的百分比
在 stuMarks 表的 writtenExam 列创建索引:
USE stuDB
GO
IF EXISTS (SELECT name FROM sysindexes
WHERE name = 'IX_writtenExam')
DROP INDEX stuMarks.IX_writtenExam
/*-- 笔试列创建非聚集索引:填充因子为 30 % --*/
CREATE NONCLUSTERED INDEX IX_writtenExam
ON stuMarks(writtenExam)
WITH FILLFACTOR= 30
GO
/*----- 指定按索引 IX_writtenExam 查询 ----*/
SELECT * FROM stuMarks (INDEX=IX_writtenExam)
WHERE writtenExam BETWEEN 60 AND 90
虽然我们可以指定 SQL Server 按哪个索引进行数据查询,但一般不需要我们人工指定。 SQL Server 将会根据我们创建的索引,自动优化查询 。
索引的优缺点
• 优点
– 加快访问速度
– 加强行的唯一性
• 缺点
– 带索引的表在数据库中需要更多的存储空间
– 操纵数据的命令需要更长的处理时间,因为它们需要对索引进行更新
创建索引的指导原则
• 请按照下列标准选择建立索引的列。
– 该列用于频繁搜索
– 该列用于对数据进行排序
• 请不要使用下面的列创建索引:
– 列中仅包含几个不同的值。
– 表中仅包含几行。为小型表创建索引可能不太划算,因为 SQL Server 在索引中搜索数据所花的时间比在表中逐行搜索所花的时间更长
发表评论
-
mysql 5.7.14-winx64 安装
2016-08-22 22:40 507下载,解压 bin目录增加入path变量 管理员身份启动 ... -
toad 未安装oracle客户端 配置
2013-11-15 11:08 15551. 下载toad软件和oracle的instantcli ... -
linux oracle 12514错误解决办法
2013-07-30 17:34 1880解决方法: 1. 打开<OracleHome> ... -
ora-00054:resource busy
2013-07-24 16:26 883当某个数据库用户在数据库中插入、更新、删除一个表的数据,或 ... -
Oracle 启动
2013-07-03 09:57 708$ su - oracle $ sqlplus / as ... -
sqlserver字符串拆分(split)方法汇总
2012-05-15 13:58 1003--方法0:动态SQL法 declare @s varcha ... -
T-SQL之SET ANSI_NULLS
2012-03-21 14:20 1034当 SET ANSI_NULLS 为 ON 时 ... -
sqlserver 获得外键关联表名
2012-03-14 18:59 1731获取表修改时间:SELECT modify_date FR ... -
sql server 查询表名,列名等
2012-03-14 18:23 4513--1:获取当前数据库中的所有用户表 select Name ... -
连接mysql和 建索引花费
2012-02-07 10:23 952mysql -h192.168.0.150 -uroot -p ... -
查询乱码和按月查询
2012-01-04 15:29 928SET character_set_connection=ut ... -
PL/SQL 控制语句
2011-12-01 11:04 876条件语句: if...then...else语句: dec ... -
Oracle 游标
2011-11-30 16:53 1186游标是构建在L/SQL中用来查询数据库、获取记录集合 ... -
Oracle 集合 方法
2011-11-30 11:22 774The COUNT Method: 用于计算 associa ... -
oracle 集合
2011-11-29 17:07 651记录(Record): 由单行多 ... -
oracle PL/SQL 标量数据类型
2011-11-28 18:17 1212字符数据类型: 类型名称 描述 char ... -
oracle 情景查询
2011-11-25 14:26 756decode()函数: 类似于if ... then ... ... -
Oralce 层次查询
2011-11-25 14:00 697初始化数据库,创建表和导入数据:create tab ... -
Oracle 时间和字符串的装换
2011-11-24 16:33 937使用to_char()函数可以完成从日期数据到字符串的准换过 ... -
Pl/SQL Developer 常用技巧
2011-11-24 10:55 679PL/SQL Developer记住登陆 ...
相关推荐
SQL Server 索引中 include 的魅力(具有包含性列的索引) SQL Server 索引中 include 的魅力(具有包含性列的索引)是指在非聚集索引中添加非键列,以扩展索引的功能,提高查询性能。通过将非键列添加到非聚集索引...
"SQL Server 索引结构及其使用(聚集索引与非聚集索引)" 数据库索引是数据库性能优化的关键技术之一。SQL Server 提供了两种索引:聚集索引(clustered index)和非聚集索引(nonclustered index)。本文将详细介绍...
SqlServer索引工作原理 在了解SqlServer索引工作原理之前,我们需要了解什么是索引。索引是一种特殊的数据库结构,它可以快速地定位和检索数据。索引的作用是加快数据的查询速度,使得数据库中的数据更易于管理和...
该ppt详细描述sqlserver索引优化时带来的查询性能提升和更新锁开销,最后介绍表设计,字段数据类型的选择及使用适当的冗余减少表连接
SQLServer中的索引碎片是影响数据库性能的重要因素,它分为外部碎片和内部碎片两种类型。外部碎片发生在索引页不在其逻辑顺序上时,导致查询过程中需要额外的页切换,尤其是对于返回有序结果集的查询,这将显著降低...
优化 SQL Server 索引的小技巧 SQL Server 中有多种可以让您检测、调整和优化 SQL Server 性能的工具。其中,优化数据库索引的使用是提高 SQL Server 性能的关键因素之一。在本文中,我们将讨论如何用 SQL Server ...
用于SqlServer的索引重建,全语句实现,可根据实际情况进行部分关键表的索引重建。
Sqlserver索引分析,Sqlserver索引缺失,Sqlserver索引建议
SQLserver索引失效举例.txt
### SQL Server 索引基础知识知识点汇总 #### 一、记录数据的基本格式 - **数据页作为基础单位**:在 SQL Server 中,数据页是最基本的存储单位,无论是缓存中的数据还是磁盘上的物理存储,都以数据页的形式存在。...
SQL Server 重新组织和重新生成索引 在 SQL Server 中,索引的碎片可能会对查询性能产生影响,因此需要对索引进行维护。SQL Server 2005 提供了重新组织和重新生成索引的功能,以修复索引碎片。 重新组织索引 ...
### SQL Server索引设计经验谈 #### 摘要 本文旨在探讨Microsoft SQL Server中的索引设计技巧,尤其是如何通过合理的索引策略来优化查询性能。通过对聚集索引与非聚集索引的选择、索引列的排序方式、填充因子的...
尤其在使用SQL Server数据库时,了解并合理利用其索引结构能够显著提升数据检索效率。本文将详细探讨SQL Server中的索引结构以及如何恰当地使用它们。 首先,索引在SQL Server中分为两大类:聚集索引和非聚集索引。...
资源名称:SQLServer索引调优实践资源截图: 资源太大,传百度网盘了,链接在附件中,有需要的同学自取。
我在这里只讨论两种SQLServer索引,即clustered索引和nonclustered索引。当考察建立什么类型的索引时,你应当考虑数据类型和保存这些数据的column。同样,你也必须考虑数据库可能用到的查询类型以及使用的最为频繁的...
### SQL Server索引文件迁移到文件组的知识点详解 #### 一、背景介绍 在SQL Server数据库管理系统中,为了提高数据库性能和管理效率,经常需要对数据库进行优化。其中一种重要的优化手段就是合理地管理数据库文件...
深入理解SqlServer索引机制及合理优化数据库
SQLServer查看缺失索引
### SQL Server 建立索引相关知识点 #### 一、建立索引 索引是在数据库表中的数据列上创建的一种特殊的数据结构,其目的是为了加快数据检索速度。索引类似于书籍的目录,通过索引可以快速定位到所需的数据行,从而...