资源描述:
《数据库实验心得范文》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、数据库实验心得范文 我在sqlserver索引基础知识系列中,第一篇就讲了记录数据的基本格式。那里主要讲解的是,数据库的最小读存单元:数据页。一个数据页是8k大小。 对于数据库来说,它不会每次有一个数据页变化后,就存到硬盘。而是变化达到一定数量级后才会作这个操作。这时候,数据库并不是以数据页来作为操作单元,而是以64k的数据(8个数据页,一个区)作为操作单元。 区是管理空间的基本单位。一个区是八个物理上连续的页(即64kb)。这意味着sqlserver数据库中每mb有16个区。 为了使空间分配更有效,sqlserver不会
2、将所有区分配给包含少量数据的表。sqlserver有两种类型的区: 统一区,由单个对象所有。区中的所有8页只能由所属对象使用。 混合区,最多可由八个对象共享。区中八页的每页可由不同的对象所有。 通常从混合区向新表或索引分配页。当表或索引增长到8页时,将变成使用统一区进行后续分配。如果对现有表创建索引,并且该表包含的行足以在索引中生成8页,则对该索引的所有分配都使用统一区进行。 为何会这样呢? 其实很简单: 读或写8kb的时间与读或写64kb的时间几乎相同。 在8kb到64kb范围之内,单个磁盘i/o传输操
3、作所花的时间主要是磁盘取数臂和读/写磁头运动的时间。 因此,从数学上来讲,当需要传输64kb以上的sql数据时, 尽可能地执行64kb磁盘传输是有益的,即分成数个64k的操作。 因为64kb传输基本上与8kb传输一样快,而每次传输的sqlserver数据是8kb传输的8倍。 我们通过一个实例来看有and操作符时候的最常见的一种情况。我们有下面一个表, createtable[dbo].[member]([member_no][dbo].[numeric_id]identity(1,1)notnull,[lastnam
4、e][dbo].[shortstring]notnull,[firstname][dbo].[shortstring]notnull,[middleinitial][dbo].[letter]null,[street][dbo].[shortstring]notnull,[city][dbo].[shortstring]notnull,[state_prov][dbo].[statecode]notnull,[country][dbo].[countrycode]notnull,[mail_code][dbo].[mailcode]notnull
5、,[phone_no][dbo].[phonenumber]null,[photograph][image]null,[issue_dt][datetime]notnulldefault(getdate()),[expr_dt][datetime]notnulldefault(dateadd(year,1,getdate())),[region_no][dbo].[numeric_id]notnull,[corp_no][dbo].[numeric_id]null,[prev_balance][money]nulldefault(0),[curr
6、_balance][money]nulldefault(0),[member_code][dbo].[status_code]notnulldefault('')) 这个表具备下面的四个索引: 索引名细节索引的列 member_corporation_linknonclusteredlocatedonprimarycorp_no member_identclustered,unique,primarykeylocatedonprimarymember_no member_region_linknonclustered
7、locatedonprimaryregion_no memberfirstnamenonclusteredlocatedonprimaryfirstname 当我们执行下面的sql查询时候, selectm.member_no,m.firstname,m.region_nofromdbo.memberasmwherem.firstnamelike'k%'andm.region_no>6andm.member_no<5000go sqlserver会根据索引方式,优化成下面方式来执行。 selecta.member_n
8、o,a.firstname,b.region_nofrom(selectm.member_no,m.firstnamefromdbo.m