资源描述:
《sql数据库实训总结》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、sql数据库实训总结sql数据库实训总结,SQL是StructuredQueryLanguage(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。下面是分享的sql数据库实训总结,欢迎阅读!sql数据库实训总结我在sqlserver索引基础知识系列中,第一篇就讲了记录数据的基本格式。那里主要讲解的是,数据库的最小读存单元:数据页。一个数据页是8k大小。对于数据库来说,它不会每次有一个数据页变化后,就存到硬盘。而是变化迖到一定数量级后才会作这个操作。这时候,数据库并不是以数据页来作为操作单元,而是以64k的数据(8个数据
2、页,一个区)作为操作单元。区是管理空间的基本单位。一个区是八个物理上连续的页(即64kb)。这意味着sqlserver数据库中每mb有16个区。为了使空间分配更有效,sqlserver不会将所有区分配给包含少量数据的表。sqlserver有两种类型的区:统一区,由单个对象所有。区中的所有8页只能由所属对象使用。混合区,最多可由八个对象共享。区中八页的每页可由不同的对象所有。通常从混合区向新表或索引分配页。当表或索引增长到8页时,将变成使用统一区进行后续分配。如果对现有表创建索引,并且该表包含的行足以在索引中生成8页,则对该索引的所有分配都使用统一区进行。为何会
3、这样呢?其实很简单:读或写8kb的时间与读或写64kb的时间几乎相同。在8kb到64kb范围之内,单个磁盘i/o传输操作所花的时间主要是磁盘取数臂和读/写磁头运动的时间。此,从数学上来讲,当需要传输64kb以上的sql数据时,尽可能地执行64kb磁盘传输是有益的,即分成数个64k的操作为64kb传输基本上与8kb传输一样快,而每次传输的sqlserver数据是8kb传输的8倍。我们通过一个实例来看有and操作符时候的最常见的一种情况。我们有下面一个表,createtable.(.identity(1,1)notnull,.notnull,.notnull,.n
4、ull,.notnull,.notnull,notnull,.notnull,.notnull,.null,null,notnulldefault(getdateO),notnulldefault(dateadd(year,1,getdate())),.notnull,.null,nulldefault(0),nulldefault(0),.notnulldefault(‘‘))这个表具备下面的四个索引索引名细节索引的列member_corporation_linknonclusteredlocatedonprimarycorp_nomember_identc
5、lustered,unique,primarykeylocatedonprimarymember_nomember_region_linknonclusteredlocatedonprimaryregion_nomeraberfirstnamenonclusteredlocatedonprimaryfirstname当我们执行下面的sql查询时候,selectm.member_no,m.firstname,m.region_nofromdbo.memberasmwherem.firstnamelike‘kVandm.region一no>6andm.member
6、_noselecta.member_no,a.firstname,b.region_nofrom(selectm.member_no,m.firstnamefromdbo.memberasmwherem.firstnamelike‘k%’andm.member—no(selectm.member_no,m.region_nofromdbo.memberasmwherem.region_no>6)b--这个查询可以直接使用member_region_link非聚集索引,而且这个非聚集索引覆盖了所有查询列一实际执行时,只需要逻辑读取10次wherea.member
7、no=b.memberno不信,你可以看这两个sql的执行计划,以及逻辑读信息,都是一样的。其实上面的sql,如果优化成下面的方式,实际的逻辑读消耗也是一样的。为何sqlserver不会优化成下面的方式。是因为and操作符优化的另外一个原则。1/26的数据和1/6的数据找交集的速度要比1/52的数据和1/3的数据找交集速度要慢。selecta.member_no,a.firstname,b.region_nofrom(selectm.member_no,m.firstnamefromdbo.memberasmwherem.firstnamelike‘k%’一1
8、/26数据)a,(selectm.me