SQLServer中数据库文件的存放方式,文件和文件组

 更新时间:2011年12月27日 00:05:46   作者:  
上次我关于索引的文章有几个园友发站内信问我如何将索引和表存储在不同的硬盘上。我觉的需要专门写一篇文章来讲述一下文件和文件组应该更容易理解

简介

    在SQL SERVER中,数据库在硬盘上的存储方式和普通文件在Windows中的存储方式没有什么不同,仅仅是几个文件而已.SQL SERVER通过管理逻辑上的文件组的方式来管理文件.理解文件和文件组的概念对于更好的配置数据库来说是最基本的知识。

理解文件和文件组

    在SQL SERVER中,通过文件组这个逻辑对象对存放数据的文件进行管理.

    先来看一张图:

       1

    我们看到的逻辑数据库由一个或者多个文件组构成

    而文件组管理着磁盘上的文件.而文件中存放着SQL SERVER的实际数据.

为什么通过文件组来管理文件

    对于用户角度来说,需对创建的对象指定存储的文件组只有三种数据对象:表,索引和大对象(LOB)

    使用文件组可以隔离用户和文件,使得用户针对文件组来建立表和索引,而不是实际磁盘中的文件。当文件移动或修改时,由于用户建立的表和索引是建立在文件组上的,并不依赖具体文件,这大大加强了可管理性.

    还有一点是,使用文件组来管理文件可以使得同一文件组内的不同文件分布在不同的硬盘中,极大的提高了IO性能.

    SQL SERVER会根据每个文件设置的初始大小和增长量会自动分配新加入的空间,假设在同一文件组中的文件A设置的大小为文件B的两倍,新增一个数据占用三页(Page),则按比例将2页分配到文件A中,1页分配到文件B中.

文件的分类

  •     首要文件:这个文件是必须有的,而且只能有一个。这个文件额外存放了其他文件的位置等信息.扩展名为.mdf
  •     次要文件:可以建任意多个,用于不同目的存放.扩展名为.ndf
  •     日志文件:存放日志,扩展名为.ldf

    在SQL SERVER 2008之后,还新增了文件流数据文件和全文索引文件.

    上述几种文件名扩展名可以随意修改,但是我推荐使用默认的扩展名。

    我们可以通过如下语句查看数据库中的文件情况:

    2

     还有一点要注意的是,如果一个表是存在物理上的多个文件中时,则表的数据页的组织为N(N为具体的几个文件)个B树.而不是一个对象为一个B树.

创建和使用文件组

    创建文件或是文件组可以通过在SSMS中或者使用T-SQL语句进行。对于一个数据库来说,既可以在创建时增加文件和文件组,也可以向现有的数据库添加文件和文件组.这几种方式大同小异.下面来看一下通过SSMS向现有数据库添加文件和文件组.

    首先创建文件组:

    3

    文件组创建好后就可以向现有文件组中添加文件了:

    4

下面我们就可以通过语句将创建的表或者索引加入到新的文件组中了:

5

使用多个文件的优点与缺点

    通常情况下,小型的数据库并不需要创建多个文件来分布数据。但是随着数据的增长,使用单个文件的弊端就开始显现。

    首先:使用多个文件分布数据到多个硬盘中可以极大的提高IO性能.

    其次:多个文件对于数据略多的数据库来说,备份和恢复都会轻松很多.我碰见过遇到一个150G的数据库,手头却没有这么大的存储设备…

    但是,在数据库的世界中,每一项好处往往伴随着一个坏处:

    显而易见,使用多文件需要占用更多的磁盘空间。这是因为每个文件中都有自己的一套B树组织方式,和自己的增长空间。当然了,还有一套自己的碎片-.-但是在大多数情况下,多占点磁盘空间带来的弊端要远远小于多文件带来的好处.

总结

  本文对SQL SERVER中文件和文件组的概念进行了简单阐述,并在文中讲述了文件和文件组的配置方式。按照业务组织好不同的文件组来分布不同的文件,使得性能的提升,对于你半夜少接几个电话的帮助是灰常大滴:-)

相关文章

  • 使用 SQL 语句实现一个年会抽奖程序的代码

    使用 SQL 语句实现一个年会抽奖程序的代码

    这篇文章主要介绍了使用 SQL 语句实现一个年会抽奖程序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • sql数据库修改sa密码操作教程

    sql数据库修改sa密码操作教程

    本文将介绍SQL Server Sa用户的密码修改方法,需要了解更多的朋友可以参考下
    2012-11-11
  • SQL Server 触发器 表的特定字段更新时,触发Update触发器

    SQL Server 触发器 表的特定字段更新时,触发Update触发器

    另外再补充一句:insert和update的数据都会保存在临时表中,所以使用inserted可以取出这些数据,删除时使用deleted可以取出被删除的数据
    2009-08-08
  • 省市县三级联动的SQL语句

    省市县三级联动的SQL语句

    这篇文章主要介绍了省市县三级联动的SQL语句,包括建表及插入数据,需要的朋友可以参考下
    2014-04-04
  • SQL服务器无法启动的解决方法

    SQL服务器无法启动的解决方法

    这篇文章主要为大家详细介绍了SQL服务器无法启动的解决方法,以及SQLserverAgent无法启动的解决方法
    2017-03-03
  • SQL Server数据库设置自动备份策略的完整步骤

    SQL Server数据库设置自动备份策略的完整步骤

    这篇文章主要给大家介绍了关于SQL Server数据库设置自动备份策略的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用sql server具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-09-09
  • SQLServer 跨库查询实现方法

    SQLServer 跨库查询实现方法

    不使用链接的服务器名,而提供特殊的连接信息,并将其作为四部分对象名的一部分
    2012-04-04
  • SQL Server查询某个字段在哪些表中存在

    SQL Server查询某个字段在哪些表中存在

    这篇文章介绍了SQL Server查询某个字段在哪些表中存在的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • 使用SQL语句创建数据库与创建表操作指南

    使用SQL语句创建数据库与创建表操作指南

    这篇文章主要给大家介绍了关于使用SQL语句创建数据库与创建表操作的相关资料,创建数据库是数据库管理的第一步,而SQL语句是创建数据库的基本工具,需要的朋友可以参考下
    2023-08-08
  • SQL Server使用T-SQL语句批处理

    SQL Server使用T-SQL语句批处理

    这篇文章介绍了SQL Server使用T-SQL语句进行批处理的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05

最新评论