资源描述
第3章创建和管理数据库,创建数据库创建文件组管理数据库数据结构介绍,数据库存储结构,数据库的存储结构逻辑存储结构数据库是由哪些性质的信息所组成。实际上,SQLServer的数据库是由诸如表、视图、索引等各种不同的数据库对象所组成。物理存储结构讨论数据库文件是如何在磁盘上存储的,数据库在磁盘上是以文件为单位存储的,由数据库文件和事务日志文件组成,一个数据库至少应该包含一个数据库文件和一个事务日志文件。,数据库文件,主数据库文件一个数据库可以有一个或多个数据库文件,一个数据库文件只能属于一个数据库。当有多个数据库文件时,有一个文件被定义为主数据库文件(简称为主文件),其扩展名为mdf。主数据库文件用来存储数据库的启动信息以及部分或者全部数据,是所有数据库文件的起点,包含指向其它数据库文件的指针。一个数据库只能有一个主数据库文件。,数据库文件,辅助数据库文件一个用于存储主数据库文件中未存储的剩余数据和数据库对象,一个数据库可以没有辅助数据库文件,但也可以同时拥有多个辅助数据库文件。辅助数据库文件的扩展名为ndf(简称为辅助文件)。,数据库文件,事务日志文件一个存储数据库的更新情况等事务日志信息,当数据库损坏时,管理员使用事务日志恢复数据库。每一个数据库至少必须拥有一个事务日志文件,而且允许拥有多个日志文件。事务日志文件的扩展名为ldf,日志文件的大小至少是512KB。SQLServer事务日志采用提前写入的方式。,创建数据库,1使用向导创建数据库2使用企业管理器创建数据库3使用Transact-SQL语言创建数据库,使用T-SQL语言创建数据库,CREATEDATABASESampleONPRIMARY(NAME=SampleData,FILENAME=c:ProgramFiles.DataSample.mdf,SIZE=10MB,MAXSIZE=15MB,FILEGROWTH=20%)LOGON(NAME=SampleLog,FILENAME=c:ProgramFiles.DataSample.ldf,SIZE=3MB,MAXSIZE=5MB,FILEGROWTH=1MB),主数据库文件,事务日志文件,逻辑文件名,物理文件名,文件增长量,建立数据库的定义:数据库的名称数据库的大小数据库将驻留在哪一个文件中,Transact-SQL语言的命令格式说明:用括起来的内容表示是可选的;,n表示重复前面的内容;用括起来表示在实际编写语句时,用相应的内容替代;用括起来表示是必选的;类似A|B的格式,表示A和B只能选择一个,不能同时都选。,使用Transact-SQL语言创建数据库,CREATEDATABASEdatabase_nameONPRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),nLOGON(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),n,使用Transact-SQL语言创建数据库,database_name:数据库的名称。数据库名称在服务器中必须唯一,最长为128个字符,并且要符合标识符的命名规则。每个服务器管理的数据库最多为32767个。PRIMARY:用于指定主文件组中的文件。如果不指定PRIMARY关键字,则在命令中列出的第一个文件将被默认为主文件。SIZE:指定数据库的初始容量大小。如果没有指定主文件的大小,则SQLServer默认其与模板数据库中的主文件大小一致,其它数据库文件和事务日志文件则默认为1MB。指定大小的数字size可以使用KB、MB、GB和TB后缀,默认的后缀为MB。Size中不能使用小数,其最小值为512KB,默认值为1MB。主文件的size不能小于模板数据库中的主文件。,使用Transact-SQL语言创建数据库,MAXSIZE:指定操作系统文件可以增长到的最大尺寸。如果没有指定,则文件可以不断增长直到充满磁盘。FILEGROWTH:指定文件每次增加容量的大小,当指定数据为0时,表示文件不增长。增加量可以确定为以KB、MB作后缀的字节数或以%作后缀的被增加容量文件的百分比来表示。默认后缀为MB。如果没有指定FILEGROWTH,则默认值为10%,每次扩容的最小值为64KB。,使用Transact-SQL语言创建数据库,创建数据库(举例),例3-2-1:使用CREATEDATABASE创建一个student数据库,所有参数均取默认值。例3-2-2:创建一个Student1数据库,该数据库的主文件逻辑名称为Student1_data,物理文件名为Student1.mdf,初始大小为10MB,最大尺寸为无限大,增长速度为10%;数据库的日志文件逻辑名称为Student1_log,物理文件名为Student1.ldf,初始大小为1MB,最大尺寸为5MB,增长速度为1MB。,例3-2-3:创建一个指定多个数据文件和日志文件的数据库。该数据库名称为students,有1个10MB和1个20MB的数据文件和2个10MB的事务日志文件。数据文件逻辑名称为student1和student2,物理文件名为student1.mdf和student2.mdf。主文件是student1,由primary指定,两个数据文件的最大尺寸分别为无限大和100MB,增长速度分别为10%和1MB。事务日志文件的逻辑名为studentlog1和studentlog2,物理文件名为studentlog1.ldf和studentlog2.ldf,最大尺寸均为50MB,文件增长速度为1MB。,创建数据库(举例),第2章创建和管理数据库,创建数据库创建文件组管理数据库数据结构介绍,创建文件组,文件组的概念文件组是SQLServer中一个或多个文件的命名集合,它构成分配或用于数据库管理的单个单元文件组的使用场合当有多个磁盘,希望把文件分布在这些磁盘上以提高性能文件组的类型两种文件组:主文件组和用户定义文件组主文件组包含主文件的文件组用户定义的文件组在首次创建或以后更改数据库时,用户明确创建的任何文件组,创建文件组(续),创建文件组(续),ALTERDATABASENorthwindADDFILEGROUPOrderHistoryGroupGOALTERDATABASENorthwindADDFILE(NAME=OrdHistYear1,FILENAME=c:HistoryDBOrdHist1.ndf,SIZE=5MB)TOFILEGROUPOrderHistoryGroupGO,第2章创建和管理数据库,创建数据库创建文件组管理数据库数据结构介绍,管理数据库,查看数据库信息修改数据库收缩数据库或文件删除数据库事务日志的工作过程,检索数据库信息,使用系统存储过程来显示数据库以及数据库参数的信息sp_helpdbsp_helpdb数据库名,使用Transact-SQL语言修改数据库只有数据库管理员或具有CREATEDATABASE权限的数据库所有者才有权执行该语句。ALTERDATABASE语句的语法格式如下:,修改数据库,Alterdatabasedatabasenameaddfile,ntofilegroupfilegroupname|addlogfile,n|removefilelogical_file_name|removefilegroupfilegroup_name|modifyfile|modifyname=new_databasename|addfilegroupfilegroup_name|modifyfilegroupfilegroup_namefilegroup_property|name=new_filegroup_name,修改数据库,addfile,ntofilegroupfilegroupname:表示向指定的文件组中添加新的数据文件。addlogfile,n:增加新的日志文件。removefilelogical_file_name:删除指定的操作系统文件。removefilegroupfilegroup_name:删除指定的文件组。modifyfile:修改某个操作系统文件。modifyname=new_databasename:重命名数据库。addfilegroupfilegroup_name:增加一个文件组。modifyfilegroupfilegroup_name:修改某个指定文件组的属性。,修改数据库(举例),ALTERDATABASESampleMODIFYFILE(NAME=SampleLog,SIZE=15MB)GOALTERDATABASESampleADDFILE(NAME=SampleData2,FILENAME=c:ProgramFiles.DataSample2.ndf,SIZE=15MB,MAXSIZE=20MB)GO,管理数据文件和日志文件的增长,ALTERDATABASESampleMODIFYFILE(NAME=SampleLog,SIZE=15MB)GOALTERDATABASESampleADDFILE(NAME=SampleData2,FILENAME=c:ProgramFiles.DataSample2.ndf,SIZE=15MB,MAXSIZE=20MB)GO,使文件自动增长手动扩充数据库文件添加次要数据库文件,收缩数据库或文件,收缩整个数据库企业管理器DBCCSHRINKDATABASE语句DBCCSHRINKDATABASE(数据库名,目标百分比,NOTRUNCATE|TRUNCATEONLY)收缩数据库中的一个数据文件企业管理器DBCCSHRINKFILE语句DBCCSHRINKFILE(文件名|文件id,目标大小,EMPTYFILE|NOTRUNCATE|TRUNCATEONLY)自动收缩数据库设置数据库选项autoshrink为true,收缩数据库或文件(续),收缩语句中的选项NOTRUNCATE在数据库文件中保留所释放的文件空间。(默认情况)TRUNCATEONLY文件中的所有未使用的空间释放给操作系统。不尝试将其重新分配到未分配页。当使用TRUNCATEONLY时,参数target_size和target_percent被忽略。EMPTYFILE只适用于DBCCSHRINKFILE,将清空数据文件的内容并将数据移动到同一文件组中的其他文件。,收缩数据库或文件(续),有一个小型的酒店管理系统,其营业数据为150MB,对其中的50%的数据进行备份并删除后,要把数据库立即缩小为初始的大小(即100MB)。下面哪条语句能够实现该功能?A.DBCCSHRINKFILE(JiuDianData,NOTRUNCATE)B.DBCCSHRINKDATABASE(JiuDianData,25)C.DBCCSHRINKDATABASE(JiuDianData,100)D.ALTERDATABASEJiuDianDataSETAUTO_SHRINKON,删除数据库,1利用企业管理器删除数据库2利用Drop语句删除数据库Dropdatabasedatabase_name,n说明:只有处于正常状态下的数据库,才能使用DROP语句删除。当数据库处于以下状态时不能被删除:数据库正在使用;数据库正在恢复;数据库包含用于复制的已经出版的对象。,DROPDATABASENorthwind,pubs,事务日志的工作过程,第2章创建和管理数据库,创建数据库创建文件组管理数据库数据结构介绍,数据结构介绍,数据存储方式页和扩展盘区类型管理文件空间的页跟踪表和索引的页,数据库,数据存储方式,扩展盘区(8个连续的8KB页),页(8KB),表,索引,数据,每行大小最多8060字节,数据(文件).mdf或.ndf,日志(文件).Idf,页和扩展盘区类型,页的类型(八种)页可用空间(PFS)页全局分配映射表(GAM)页和辅助全局分配映射表(SGAM)页索引分配映射表(IAM)页大容量更改映射表页差异更改映射表页数据页文本/图像页索引页,页和扩展盘区类型(续),统一扩展盘区,空闲空间,混合扩展盘区,扩展盘区的类型混合扩展盘区:包含2个或多个对象的页的扩展盘区称为“混合扩展盘区”。每张表起始于一个混合扩展盘区。主要为跟踪空间的页及包含小对象的页使用混合扩展盘区统一扩展盘区:将所有八页分配给单个对象的扩展盘区称为“统一扩展盘区”。在表或索引需要超过64KB空间时使用,管理文件空间的页,混合扩展盘区(文件第一个盘区),1,2,3,4,5,6,7,8,管理文件空间的页,每个文件的第一个扩展盘区是混合扩展盘区,包含一个文件的页首页和紧接着的三个分配页文件的页首页:包含该文件的特性信息PFS(页可用空间)页:包含有关文件中以页为单位的可用空间的信息。每个PFS页可以跟踪8000个连续页,将近64MB的数据。PFS页对每一页都有一个相应的字节,跟踪:该页是否已分配该页是在混合扩展盘区还是在统一扩展盘区该页可用空间的近似数量,管理文件空间的页(续),GAM(全局分配映射表)和SGAM(辅助全局分配映射表)页SQLServer使用GAM和SGAM页来确定未使用的扩展盘区或有未使用页的混合扩展盘区的位置GAM和SGAM配合使用,每对管理63904个扩展盘区,SQLServer使用四种类型的页来管理表和索引IAM页:包含有关表或索引使用的扩展盘区信息的分配页数据页:包含除text、ntext和image数据之外的内容文本/图像页:包含text、ntext和image内容索引页:包含索引结构,跟踪表和索引的页,跟踪表和索引的页(续),混合扩展盘区,统一扩展盘区,数据,第38页,回顾,学习完本章后,将能够:创建数据库创建文件组管理数据库描述数据结构,
展开阅读全文