《sql 2005教程 第18章 管理数据库和数据库.ppt》由会员分享,可在线阅读,更多相关《sql 2005教程 第18章 管理数据库和数据库.ppt(35页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第18章 管理数据库和数据库文件数据库文件是数据库的基础的物理形式表现,理解数据库文件的存取模式,数据文件的组合方式,将有助于数据库的管理,使备份、迁移等操作更加灵活。18.1 理解数据库文件SQL Server 2005数据库由多种类型的文件构成,本节讲述数据库文件的运行机制、涉及数据库文件和文件组的具体操作。18.1.1 理解数据存取过程在SQL Server 2005数据库中,应用程序进行数据处理操作、进行文件的存取,一般要经历四个过程,(具体内容请参照书。)18.1.2 数据库文件由数据存取过程可知,数据库存取处理过程,通常涉及到数据文件和日志文件,事实上,SQL Server 200
2、5将数据库映射为一组操作系统文件。数据和日志信息记录在不同类型的文件中,各类文件组合在一起成为一个数据库的物理表现。(具体内容请参照书。)18.1.3 数据库文件组SQL Server 2005数据库使用数据文件的方式,是将数据库对象和文件一起分成文件组。SQL Server 2005数据库支持两种类型的文件组:主文件组,该类型的文件组包含主数据文件、任何没有明确分配给其他文件组的其他文件。系统表的所有页均分配在主文件组中。用户定义文件组,该类型的文件组可以通过在CREATE DATABASE或ALTER DATABASE语句中使用FILEGROUP关键字创建。18.1.4 建立数据库文件和文
3、件组示例:在SQL Server实例上创建了一个数据库DB1。该数据库包括一个主数据文件、一个用户定义文件组和一个日志文件。主数据文件在主文件组中,而用户定义文件组包含两个次要数据文件。将用户定义文件组指定为默认文件组。然后通过指定用户定义文件组来创建表。(具体内容请参照书。)18.2 创建数据库数据库是SQL Server服务管理的数据对象,创建数据库是管理数据库的最基本的操作,本书第4章讲述了使用SQL Server Management Studio工具创建数据数据库的操作。本节将对数据库建立进行深入的讨论和讲解。18.2.1 用CREATE DATABASE语句创建数据库(具体内容请参
4、照书。)18.2.2 创建数据库的示例(具体内容请参照书。)18.2.3 数据库的所有者在SQL Server 2005数据库中,数据对象都有一个所有者,数据库的所有者一般是创建数据库的登录者。用户可以在SQL Server Management Studio工具的数据库属性中,打开“常规”选项页。可以在详细信息窗格中查看数据库的所有者。18.3 修改数据库一般情况下,数据库的是变化的,伴随着数据量的增长,用户一般要适时的对数据库进行调整。本节将列举一些常用的对数据库的修改。18.3.1 扩大数据库当数据库未使用“启用自动增长”选项时,如果数据量增加,而现有的数据库文件不能够满足用户的使用时,
5、用户需要手工增加数据库的大小,(具体内容请参照书。)18.3.2 收缩数据库在SQL Server 2005中,数据库中的每个文件都可以通过删除未使用的页的方法来减小。尽管数据库引擎会有效地重新使用空间,但某个文件多次出现无需原来大小的情况后,收缩文件就变得很有必要了。当由于业务的变化而要收缩数据库的体积时,可以“收缩”数据库,(具体内容请参照书。)18.3.3 收缩数据库文件使用SQL Server Management Studio中的对象管理器来收缩数据或日志文件。主数据文件不能收缩到小于model数据库中的主文件的大小,具体收缩数据或日志文件的操作,18.3.4 添加和删除数据文件和日
6、志文件(具体内容请参照书。)18.3.5 移动数据库文件根据业务需要,可能要求将数据库文件移动到不同的阵列、磁盘或文件目录下,以满足不同的策略的需要,如关键的数据库文件放置在阵列中,次要或者不常使用的数据文件可以放置在安全性较低一些的大容量存储器上。18.4 删除数据库用户可以使用SQL Server Management Studio图形工具或者DROP DATABASE删除数据库。删除数据库前应考虑对数据库进行完整备份,因为只有通过还原备份才能重新创建已删除的数据库。此外删除数据库前要先删除数据库中的所有数据库快照,如果存在涉及该数据库日志传送,必须先删除该日志传送。如果为事务复制发布了数
7、据库,或将数据库发布或订阅到合并复制,要求从数据库中删除复制。18.4.1 使用SQL Server Management Studio删除数据库使用SQL Server Management Studio图形工具删除数据库的操作,可参考如下步骤。(具体内容请参照书。)18.4.2 用DROP DATABASE语句删除数据库(具体内容请参照书。)18.5 分离与附加数据库可以分离数据库的数据和事务日志文件,然后将它们重新附加到同一或其他SQL Server实例。如果要将数据库更改到同一计算机的不同SQL Server实例或要移动数据库,分离和附加数据库会很有用。18.5.1 分离数据库分离数据
8、库是指将数据库从SQL Server实例中删除,但使数据库在其数据文件和事务日志文件中保持不变。之后,就可以使用这些文件将数据库附加到任何SQL Server实例,包括分离该数据库的服务器。18.5.2 附加数据库用户可以进行分离数据库的逆向操作,即可以附加复制的或分离的SQL Server数据库。附加数据库时,所有数据文件(mdf文件和ndf文件)都必须完整。如果存在任何数据文件的路径,不同于首次创建数据库或上次附加数据库时的路径,要求指定文件的当前路径。(具体内容请参照书。)18.6 理解系统数据库在已经安装好的数据库实例中,都会有系统数据库,顾名思义是数据库记录系统信息的数据库。主要包括
9、master、msdb、tempdb、model和distribution数据库,这些系统数据库对管理非常重要。本节将解释这些数据库的用途和可能的操作。18.6.1 系统数据库说明系统数据库及其功能说明如下所示。1master主数据库2msdb代理等系统数据库3tempdb临时系统数据库4model模板数据库5Resource资源数据库18.6.2 隐藏系统数据库对象用户可以在SQL Server Management Studio工具中查看到系统数据库,为了避免混淆或误操作,用户可以隐藏系统对象。具体步骤可以参考以下。(具体内容请参照书。)18.7 建立数据库快照数据库快照是数据库的只读、静
10、态视图。数据为快照为用户提供了一种机制,能够实现保存历史某一时间点的数据库。例如,在昨天的12:00对数据库做了快照,则用户可以在以后的任何时间访问昨天12:00的数据库;对于用户,数据库快照的内容是不会变化的,永远记录创建快照时的所有数据。18.7.1 工作原理(具体内容请参照书。)18.7.2 典型用途使用数据库快照的一般应用场景如下。(具体内容请参照书。)18.7.3 创建和删除数据库快照(具体内容请参照书。)18.8 数据分区管理数据分区,将数据库分区可提高其性能并易于维护。通过将一个大表拆分成更小的单个的表,只访问小部分数据的查询可以执行得更快,因为需要扫描的数据少了。本节讲述是分区
11、主要是指水平分区,SQL Server 2005数据库中实现数据水平分区的主要采用“已分区表”、“已分区视图来实现”。18.8.1 理解已分区表已分区表数据划分为分布于一个数据库中多个文件组的单元。数据是按水平方式分区的,因此多组行映射到单个的分区,对数据进行查询或更新时,表或索引将被视为单个逻辑实体。单个索引或表的所有分区都必须位于同一个数据库中。18.8.2 创建分区函数在当前数据库中创建一个函数,该函数可根据指定列的值将表或索引的各行映射到分区。使用CREATE PARTITION FUNCTION是创建已分区表或索引的第一步。(具体内容请参照书。)18.8.3 创建分区方案在当前数据库中创建一个,将已分区表的分区映射到文件组的方案的过程。分区方案建立的前提是先创建分区函数。分区方案将分区函数生成的分区映射到您定义的一组文件组。创建分区方案时,根据分区函数的参数,定义映射表分区的文件组。必须指定足够的文件组来容纳分区数。18.8.4 创建分区表创建已分区表只需要在CREATE TABLE中指对应的分区方案即可。18.8.5 创建分区表的示例示例:以下示例创建一分区表dbo.PartitionedTable,根据日期(01/01/2004,01/01/2005)进行分区,然后向分区表插入不同区域的数据,最后查看数据所在的分区。用户可以通过该示例及其说明,理解分区表的创建过程。