位置: 编程技术 - 正文

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错误和使用情况报告)

  • 母子公司的关联交易怎么看
  • 营改增后企业所得税分成比例
  • 累计扣税法什么时候实行的
  • 小规模旅游业差额增值税税率
  • 股东分红是净利润还是毛利润
  • 企业内部商品转移怎么核算
  • 企业分立房产税税收政策
  • 进口产品再销售如何缴税
  • 工程成本哪些可以抵扣
  • 季报每个月需要反写吗
  • 国外公司怎么付款给国内
  • 保洁劳务税点
  • 临时工工资作为人员成本如何做账
  • 需要清卡才能开票吗
  • 借款余额在借方说明什么
  • 事业单位计提折旧的有哪些
  • 收并购股权溢价
  • 增值税普通发票可以抵扣吗
  • 预交土增税税率
  • 税控盘服务费申报是在哪里填写
  • 网络服务费一般纳税人几个点
  • Win11安装如何跳过以太网
  • windows11快捷操作
  • 收到的进项发票要在多久前认证
  • 折旧可以计入主体成本吗
  • 电脑进步了系统
  • php 混淆
  • linux系统的
  • 公司买手机怎么做账务处理
  • php b/s
  • php r
  • 资金运动包括哪几个方面
  • 金融企业允许税前扣除的准备金
  • 改征增值税是什么意思
  • 国税代开普票能作废吗
  • 老老实实的人
  • Yii2针对游客、用户防范规则和限制的解决方法分析
  • 购买一台电脑2400元贵吗
  • 15个postgresql数据库实用命令分享
  • 建筑工程企业人才优势怎么写
  • 什么是叫资产负债表项目
  • 企业净利润怎么查询数据
  • 出纳现金日记账怎么记账
  • 投资的信托基金有哪些
  • 工程造价咨询公司招聘
  • 关于废止有关排污收费规章和规范性文件的决定
  • 新公司成立建账流程
  • 结账时应当结出每个账户的期末余额对吗
  • excel格式变了怎么办
  • solaris 2020
  • linux 解析
  • win7修改系统版本
  • win8系统怎么远程电脑
  • WIN10系统更新之后无法启动
  • win xp 虚拟内存
  • 手机如何使用windows
  • linux find命令查找文件 name
  • win8无线网络受限 重连又好了
  • js获取url的html
  • python语言基础与应用答案
  • 什么是自然数
  • bootstrap要学吗
  • android list
  • jQuery webuploader分片上传大文件
  • 利用python绘图
  • Unity3D游戏开发标准教程
  • JAVAscript字符串类型单引号和双引号意一样吗
  • 【Rayeager PX2分享】OpenCV入门之线段检测
  • bootstrap需要学多久
  • js检查邮箱格式
  • 增值税月报怎么报
  • 专项附加扣除当月填报何时生效
  • 税收六大体系和六大能力基层
  • 审批制改为备案制有什么区别
  • 通讯费报销会计分录
  • 营改增后土地增值税
  • 建筑劳务分包业务范围
  • 快手怎样代卖
  • 广东省广州市国资委
  • 公司借款给员工是否合法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设