位置: 编程技术 - 正文

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

  • 增值税附征怎么计算
  • 计提所得税比实际缴纳的少
  • 转让土地使用权营业税税率
  • 公司食堂菜金会计分录
  • 可供出售金融资产和长期股权投资
  • 个人所得税谁交
  • 自然人税收管理系统换了电脑怎么恢复数据
  • 暂估入账后没有交房产税
  • 股权评估与资产评估的关系
  • 非正常损失会计利润调整
  • 开发间接费属于期间费用吗
  • 不是本单位职工可以报销差旅费吗
  • 施工单位给你钱敢领吗
  • 试分析营改增的重大意义
  • 增值税普通发票和普通发票的区别怎么交税
  • 运输增值税专票含税价怎么算
  • 餐饮发票税钱
  • 过渡期税收优惠政策
  • 关于商业健康保险产品的规范和条件
  • 公司注销有哪些原因
  • 设备定金计入哪个科目
  • 个人独资企业免费刻章吗
  • 个税汇算清缴申报错误怎么办
  • 厂家质量问题商家有责任吗
  • 购买境外技术缴纳税费
  • 入账价值和账面余额一样吗
  • 做汽车配件销售怎么找客户
  • linux shell语句
  • 如何清除苹果手机6s垃圾
  • 建筑工程给排水的内容
  • php查看变量数据类型
  • php用法
  • 残疾人增值税即征即退税收减免备案
  • 定期定额户个人经营所得
  • 大数据可视化前端界面模板
  • 如何修改php网页内容
  • 加油费属于什么费用类别的
  • ccna 试题
  • 保安行业税率是多少
  • 遮天传官网
  • 请求转发与重定义的区别
  • 短期借款会计如何做账
  • 质保金如果以后可以退吗
  • 长期待摊费用当月发生当月要摊吗
  • 生产销售库存的会计科目
  • 外贸da付款方式的流程图
  • 固定资产折旧的影响因素
  • 打印银行电子回单有断号
  • 销售商品发生的销售退回计入什么科目
  • 未经加工的
  • 公司拨款给个人分录
  • 私募基金公司收入高吗
  • 融资租赁固定资产不属于筹资活动
  • 公司固定资产有很多种类,怎样计提折旧
  • 终端运行mysql
  • win7的系统在哪里打开
  • ubuntu not authorized to perform operation
  • mac系统怎么样
  • linux中cat命令的用法含义
  • 苹果系统数据怎么清掉
  • win7开始菜单在哪个文件夹
  • neotrace.exe - neotrace是什么进程 有什么用
  • windows8用的人少
  • win10预览版21337
  • Linux中通过Socket文件描述符寻找连接状态介绍
  • msn无法登录
  • android图形系统
  • style=display:inline
  • shell printf 变量
  • jquery滚动到底部
  • python ip地址转换
  • The method setClass(Context, Class<?>) in the type Intent is not applicable for the问题
  • android动画种类
  • 轮播怎么实现
  • 21个JavaScript事件(Events)属性汇总
  • python设计二叉树结构
  • 国家税务总局23号文件
  • 一般纳税人简易征收会计分录
  • 计财科科长是什么级别
  • 房产税的计税依据及税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设