位置: 编程技术 - 正文

SQL Server误区30日谈 第29天 有关堆碎片的误区(sql server常规错误)

编辑:rootadmin
误区 #:可以通过对堆建聚集索引再DROP后进行堆上的碎片整理Nooooooooooooo!!! 对堆建聚集索引再DROP在我看来是除了收缩数据库之外最2的事了。 如果你通过sys.dm_db_index_physical_stats(或是老版本的DBCC SHOWCONTIG)看到堆上有碎片,绝对不要通过建立聚集索引再删除聚集索引来整理堆碎片。好的做法应该是建立聚集索引之后不再删除,已经有非常多的资料阐述如何选择一个理想的聚集索引键--窄,很少变动,唯一,自增。Kimberly有一篇文章对此做了一个总结:Ever-increasing clustering key - the Clustered Index Debate..........again!(注意,是基于SQL Server 版本),对此我也有一个例子:An example of a nasty cluster key。 你也可以在SQL Server 中通过ALTER TABLE ... REBUILD来清除堆碎片,但这个做法和建立聚集索引后再删除同样邪恶。 如果你想问为什么我对此甚有成见?好吧,那我解释一下:非聚集索引中每一行都会指向一个RID或是聚集索引键的链接(详情请看:What Happens if I Drop a Clustered Index?),这个链接会以下面两种方式之一出现:如果非聚集索引所在的表是堆,那么这个链接就是一个RID。如果非聚集索引所在的表是聚集索引,那么这个链接就是聚集索引键。 如果你希望对此有更多了解,请看文章底部的链接。 因此不难看出,如果你希望将堆变为聚集索引,那么非聚集索引的所有RID就失效了,因此所有的非聚集索引都需要被重建。同样,如果删除聚集索引键,那么所有非聚集索引上存储的聚集索引键都会失效,因此也需要重建所有的非聚集索引。 简单点说,如果你建立再删除聚集索引后,所有的非聚集索引都会被重建两次。 如果你使用SQL Server 的ALTER TABLE ... REBUILD来整理堆碎片,那么同样也需要重建所有的非聚集索引,因为所有的RID都会变动。 那么,如果对于“重建”聚集索引呢?这取决于SQL Server的版本以及你是进行rebuild索引亦或是改变索引。一个常见的误区是对表进行分区将会改变聚集索引键,但事实上不会。对于那些会引起非聚集索引重建的操作,请看如下列表:Indexes From Every Angle: What happens to non-clustered indexes when the table structure is changed?。

推荐整理分享SQL Server误区30日谈 第29天 有关堆碎片的误区(sql server常规错误),希望有所帮助,仅作参考,欢迎阅读内容。

SQL Server误区30日谈 第29天 有关堆碎片的误区(sql server常规错误)

文章相关热门搜索词:sql server 错误,sql server 错误,sql server错误和使用情况报告,sql语句错误提示,sql server 错误,sqlserver1053怎么解决,sqlserver1053怎么解决,sqlserver1053怎么解决,内容如对您有帮助,希望把文章链接给更多的朋友!

SQL Server误区日谈 第天 有关备份的个误区 误区#:有关备份的个误区全是错的在开始有关备份的误区之前,如果你对备份的基础没有了解,请看之前我在TechNetMagazine的文章:UnderstandingSQLServerBack

MS SQL Server获取十二个月份的英文缩写 如果使用DATENAME()函数是取得月份的英文全称,但报表需要,只需显示月份名称缩写即可。十二个月份的英文缩写,只有五月份是全称与缩写一样,其它

Sql Server 分组统计并合计总数及WITH ROLLUP应用 WITHROLLUP在生成包含小计和合计的报表时,ROLLUP运算符很有用。ROLLUP运算符生成的结果集类似于CUBE运算符所生成的结果集。SELECT[Source],COUNT(*)ASOrderTotalFROM

标签: sql server常规错误

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

上一篇:SQL Server误区30日谈 第28天 有关大容量事务日志恢复模式的误区(sqlserver1053怎么解决)

下一篇:SQL Server误区30日谈 第30天 有关备份的30个误区(sql server错误和使用情况报告)

  • 固定资产清理应该在年报中怎么填写
  • 递延所得税资产怎么计算
  • 缴纳上一年所得税附件是哪些科目
  • 含13%的增值税怎么算
  • 购买财务软件可以抵税吗
  • 消费税的三种计税方法及各自的计算公式
  • 房地产中介门头
  • 未投入使用的固体废物
  • 发票丢失了可以报销吗
  • 固定资产用于集体福利也算经营管理需要吗
  • 房产税的原值是如何确定的
  • 混合经营销售额合并计算还是分开计算
  • 办公室零食采购台账
  • 企业所得税扣除凭证
  • 企业预收款项业务不多的情况下可以不设置预收账款科目
  • 售后维修费怎么开票
  • 增值税普通发票和普通发票的区别怎么交税
  • 中央财政补贴政策
  • 一般纳税人进项税额转出会计分录
  • 作进项税转出
  • 技术转让免征增值税
  • 项目自筹资金是什么意思
  • 公司为职工购买社保只购买三险可以吗
  • 产品预付款合同如何填写
  • 老总来公司视察
  • 资产减值损失是什么类科目
  • 一般纳税人增值税申报操作流程
  • 财务报告成本
  • 红字发票记账如何记账
  • 企业所得税按月或者按季预缴
  • 纳税人哪些支出不用交税
  • win10安装版u盘安装
  • php教程 ftp 函数
  • 退货会计应该怎么做账
  • swoole如何使用
  • 销售过程会计核算实训过程
  • 增值税专用发票上注明的价款含税吗
  • 角马群的迁徙方向
  • 非货币性资产交换和债务重组的区别
  • php实现图片上传的方法
  • 个人出租车辆交税吗
  • 人脸检测5种方式
  • 如何在wordpress嵌入amazon链接
  • 残差网络中的残差指的是什么
  • trace命令详解
  • 省外的发票能入账吗
  • 被收购方和被收购企业
  • 账本印花税怎么申报缴纳
  • 其他应收款的会计分录有哪些
  • 织梦系统如何更换网站内容
  • 应付职工薪酬中的职工是指
  • 以前年度未处理的业务
  • sql server single user
  • CentOS 7.3上SQL Server vNext CTP 1.2安装教程
  • 职工福利费的开支是什么
  • 合理损耗应计入成本吗
  • 什么情况可以作为证人
  • 本年利润会计分录怎么写
  • 个体户怎么能享受生育险
  • 实收资本的入账金额包括消费税吗
  • 发票做帐有什么用
  • 报销运输费用
  • 理财中的非保本是什么意思
  • 担保贷款中的特殊形式
  • 纳税人虽设置账簿,但账目混乱
  • 专用发票账目不对怎么办
  • mysql 高效分页
  • MySQL利用不同的流程语句输出1到200的和
  • win7历史记录在哪里
  • centos server
  • Win10 Mobile 10572升级后QQ/微信无法发送图片
  • linux查看磁盘空间大小以及分配
  • ubuntu系统如何设置永不休眠
  • 老电脑安装win7还是win8
  • node.js cookie-parser之parser.js
  • nodejs基本原理
  • unity cpu优化
  • jquery拖拽插件
  • 如何理解改革创新是时代要求
  • 武汉税务地区编号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设