位置: 编程技术 - 正文

SQL SERVER 文件和文件组(sql server中的文件位置可以很灵活)

编辑:rootadmin

1、文件和文件组的含义与关系

每个数据库有一个主数据文件.和若干个从文件。文件是数据库的物理体现。 文件组可以包括分布在多个逻辑分区的文件,实现负载平衡。文件组允许对文件进行分组,以便于管理和数据的分配/放置。例如,可以分别在三个硬盘驱动器上创建三个文件(Data1.ndf、Data2.ndf 和 Data3.ndf),并将这三个文件指派到文件组 fgroup1 中。然后,可以明确地在文件组 fgroup1 上创建一个表。对表中数据的查询将分散到三个磁盘上,因而性能得以提高。在 RAID(磁盘冗余阵列)条带集上创建单个文件也可以获得相同的性能改善。然而,文件和文件组使您得以在新磁盘上轻易地添加新文件。另外,如果数据库超过单个 Microsoft Windows 文件的最大大小,则可以使用次要数据文件允许数据库继续增长。

2、文件、文件组在实践应用中常见的问题

通常情况下我们构造的数据库都只有两个文件,mdf文件和ldf文件.但是这样有两个缺点:

(一)容易导致文件过大

我们知道,mdf文件是数据库文件,这样的话也就意味着随着数据库的增大mdf就会相应的增大,显然在现在的应用中数据膨胀是太常见的事情了,当你的应用变大后,mdf文件也会变大,然而windows对文件的大小是有要求的,这样的话很容易导致mdf文件达到windows所允许的文件大小的界限(于是数据库就崩溃了)。

(二)没有利用到磁盘阵列

大型的服务器好多都有磁盘阵列,你可以把磁盘阵列简单的假象成n个一块转动的磁盘,磁盘阵列的设计是希望通过多个磁盘的串联来得到更大的读写效率.但是如果你的数据库只有一个mdf文件(ldf文件暂时不考虑),那么你总是只能够利用这个磁盘阵列里面的一个磁盘而已.那样的话昂贵的磁盘阵列的效率就由并联变成串联了.试想如果我们能够让mdf分散成多个文件,比如说磁盘阵列上的每个磁盘中都分配一个文件,然后把mdf中的数据分散到各个文件中,我在读取的时候就是串联的读取了,这样就充分的利用了磁盘阵的存取效能.

这两个问题平常我们没有遇到过(条件不具备),但是做大型的服务开发的时候这几乎是致命的.

3、查询文件组和文件语句

这在下,运行

SELECT df.[name], df.physical_name, df.[size], df.growth, f.[name][filegroup], f.is_default FROM sys.database_files df JOIN sys.filegroups f ON df.data_space_id = f.data_space_id

4、MSDN官方解释

了解文件和文件组

每个 SQL Server 数据库至少具有两个操作系统文件:一个数据文件和一个日志文件。数据文件包含数据和对象,例如表、索引、存储过程和视图。日志文件包含恢复数据库中的所有事务所需的信息。为了便于分配和管理,可以将数据文件集合起来,放到文件组中。

数据库文件

SQL Server 数据库具有三种类型的文件,如下表所示:

文件 说明

主要

主要数据文件包含数据库的启动信息,并指向数据库中的其他文件。用户数据和对象可存储在此文件中,也可以存储在次要数据文件中。每个数据库有一个主要数据文件。主要数据文件的建议文件扩展名是 .mdf。

次要

次要数据文件是可选的,由用户定义并存储用户数据。通过将每个文件放在不同的磁盘驱动器上,次要文件可用于将数据分散到多个磁盘上。另外,如果数据库超过了单个 Windows 文件的最大大小,可以使用次要数据文件,这样数据库就能继续增长。

次要数据文件的建议文件扩展名是 .ndf。

事务日志

事务日志文件保存用于恢复数据库的日志信息。每个数据库必须至少有一个日志文件。事务日志的建议文件扩展名是 .ldf。

例如,可以创建一个简单的数据库 Sales,其中包括一个包含所有数据和对象的主要文件和一个包含事务日志信息的日志文件。也可以创建一个更复杂的数据库 Orders,其中包括一个主要文件和五个次要文件。数据库中的数据和对象分散在所有六个文件中,而四个日志文件包含事务日志信息。

默认情况下,数据和事务日志被放在同一个驱动器上的同一个路径下。这是为处理单磁盘系统而采用的方法。但是,在生产环境中,这可能不是最佳的方法。建议将数据和日志文件放在不同的磁盘上。

文件组

每个数据库有一个主要文件组。此文件组包含主要数据文件和未放入其他文件组的所有次要文件。可以创建用户定义的文件组,用于将数据文件集合起来,以便于管理、数据分配和放置。

例如,可以分别在三个磁盘驱动器上创建三个文件 Data1.ndf、Data2.ndf 和 Data3.ndf,然后将它们分配给文件组 fgroup1。然后,可以明确地在文件组 fgroup1 上创建一个表。对表中数据的查询将分散到三个磁盘上,从而提高了性能。通过使用在 RAID(独立磁盘冗余阵列)条带集上创建的单个文件也能获得同样的性能提高。但是,文件和文件组使您能够轻松地在新磁盘上添加新文件。

下表列出了存储在文件组中的所有数据文件。

文件组 说明

主要

包含主要文件的文件组。所有系统表都被分配到主要文件组中。

用户定义

用户首次创建数据库或以后修改数据库时明确创建的任何文件组。

默认文件组

如果在数据库中创建对象时没有指定对象所属的文件组,对象将被分配给默认文件组。不管何时,只能将一个文件组指定为默认文件组。默认文件组中的文件必须足够大,能够容纳未分配给其他文件组的所有新对象。

PRIMARY 文件组是默认文件组,除非使用 ALTER DATABASE 语句进行了更改。但系统对象和表仍然分配给 PRIMARY 文件组,而不是新的默认文件组。

推荐整理分享SQL SERVER 文件和文件组(sql server中的文件位置可以很灵活),希望有所帮助,仅作参考,欢迎阅读内容。

SQL SERVER 文件和文件组(sql server中的文件位置可以很灵活)

文章相关热门搜索词:sql server的文件包括哪两种,sql server2008的文件包括,sql server中的文件位置可以很灵活,sql server的数据文件,sql server的文件类型,sqlserver文件和文件组与数据库还原,sql server的文件包括什么,sql server sql文件,内容如对您有帮助,希望把文章链接给更多的朋友!

SQL server 随机数函数 不过还是希望老鸟们多多指教了,现在切入正题:随机函数:rand()在查询分析器中执行:selectrand(),可以看到结果会是类似于这样的随机小数:0.

SQLServer Top语句参数化方法 declare@TopCountintset@TopCount=selecttop(@TopCount)*fromAdventureWorks.HumanResources.Employee如果有Like等字句,一定要拼Sql的话,也应该使用sp_executesql来执行,示例如下

SQLServer EVENTDATA()函数来获取DDL 触发器信息 --CreatealogtableCREATETABLETriggerLog(LogInfoxml)--CreateadummytabletodeletelateronCREATETABLETableToDelete(IdintPRIMARYKEY)--新建一个新表,作为删除实验表INSERTINTOTableToDeleteVALUES(1

标签: sql server中的文件位置可以很灵活

本文链接地址:https://www.jiuchutong.com/biancheng/349108.html 转载请保留说明!

上一篇:mssql 两表合并sql语句(sql将两个表的数据合并)

下一篇:SQL server 随机数函数(sql server随机数函数)

  • 境外旅客购物离境退税条件
  • 小规模纳税人的认定标准是什么
  • 留抵退税手续
  • 事业单位有那种
  • 发票抬头不完整能用吗
  • 为了贷款支付的土地评估费用怎么会计处理?
  • 注册资本没有到账怎么做账
  • 意外死亡公司赔偿多少标准
  • 在建工程预付款项记入什么会计科目
  • 机票保险可以报销入账吗
  • 融资租赁购入固定资产开票吗
  • 城市垃圾处置费计入会计什么科目
  • 股权投资损失怎么算出来的
  • 股东私人垫支公司支付零星材料的会计分录
  • 员工借款收不回来账务处理
  • 现金比率在多少比较合适
  • mac如何登陆两个微信
  • 以太网连接网络
  • deepin如何
  • scanexplicit.exe - scanexplicit是什么进程 作用是什么
  • php数据库分页是怎么实现的
  • php缓存优化
  • linux漏洞复现
  • 预提费用的对应科目
  • 进程program
  • 增值税普通发票和专用发票有什么区别
  • 广告费增值税税目是什么
  • 工业制品买卖
  • 一文读懂谢娜张杰购房跳单事件始末
  • php实现分页显示
  • 勾选确认发票后能撤销吗
  • js文件合并工具
  • object.assign(this.$data, this.$options.data())
  • 数据安全数据目录
  • 短信php源码
  • 货币盘盈盘亏账怎么算
  • 哪些情形视同从境外取得收入:
  • 企业所得税季初和季末怎么算
  • 工厂的污水处理站作用
  • 总结帝国cms内容是什么
  • 研发费用成本化和费用化
  • 限额领料单属于什么凭证多选题
  • 筹建期发生的费用会计分录
  • 无形资产摊销计算方法
  • 进项税大于销项税怎么抵扣
  • 简易征收的进项税额转出
  • 发票加上税额之后怎么还多了呢
  • 公司向法人借款有税务风险吗
  • 银行承兑汇票到期日后多久可以承兑
  • 出口退税申报分录怎么写
  • 印花税是如何计征的
  • 政府补助收入总额法会计分录
  • 收到厂家返利账务处理
  • 免抵退退税额
  • 设备丢失查找
  • 内账税费计入什么科目
  • 总账的建立
  • window 开机启动
  • linux信号机制的原理
  • 步步简笔画
  • 解决ubuntu和win10关机重启界面不动
  • centos6.x下安装maven CentOS自动安装Maven的方法
  • windowsxp的功能介绍
  • win7如何更改欢迎界面
  • win8自带软件哪些可以卸载
  • win10ldac怎么开启
  • 路径可分为
  • jquery的checked
  • jquery的选择器有哪些举例说明
  • 谈谈网页设计中的内容
  • unity ulua
  • 如何用python画花瓣
  • Python工程师面试题 与Python基础语法相关
  • 税务局三级主办是副科吗
  • 农机行业的利润
  • 办理对外支付税务备案需要多久时间
  • 国家税务总局公告2013年第12号
  • 广州地税微信公众号
  • 临时增版
  • 如果我是科学家我会发明什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设