位置: 编程技术 - 正文

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

  • 增值税为什么不重复征税
  • 个人转让房产两年内全额计税是什么意思
  • 记账凭证附单据是有哪些
  • 农产品收购发票可以跨区域开吗
  • 电子发票红字发票怎么开
  • 房地产企业融资存在的问题
  • 销售费用现金支付
  • 汇算清缴前取得暂估发票
  • 固定资产减半征收2%申报如何填增值税纳税申报表
  • 机打发票丢失如何处理报销
  • 普票记账联可以报销吗
  • 丢失增值税专用发票
  • 一般纳税人哪些项目可以简易征收
  • 海关进口增值税专用缴款书如何抵扣
  • 企业ci
  • 可转换债券转换权的价格怎么算
  • 当月认证失控发票怎么做账处理?
  • 哪些支出可以在计算企业应纳税所得额时加计扣除
  • 对外捐赠会计和税法差异调整
  • 贴现利息会计处理
  • 事业单位自建办公用房
  • 政府会计的记账基础是什么?
  • 不得抵扣的进项税额计入哪里
  • php部署在什么服务器
  • 转出未交增值税借方余额表示什么
  • php获取ftp文件目录
  • 债劵利息怎么计算
  • php 设计模式 鸟哥
  • php7.3安装
  • php 生成缩略图
  • 高温费做账
  • 零星分布的意思
  • 现金日记账期初余额怎么算
  • 火车票可以直接去火车站买吗
  • SpringBoot+Vue实现文件上传下载功能
  • 哪些费用报销可以不用发票
  • unmount命令详解
  • 来料加工成品如何入库
  • 增值税普通发票税率
  • 专票认证对企业有影响吗
  • 铁路运费的印花税进什么科目
  • 话费补贴算工资还是福利
  • hadoop集群状态
  • 实例理解SQL中truncate和delete的区别
  • python中返回结果为true
  • 购买工业用地
  • 公司股东投资在哪里查
  • 公司股东向银行货款,与私人财产有没有关系
  • 速达建账套期初数据
  • sql模糊查询的关键字是什么
  • 土地使用税计入管理费用还是税金及附加
  • 文化建设税减免政策
  • 企业应纳税额计算直接利息的应纳税额
  • 支付给法律顾问怎么做账
  • 个人所得税多计提怎样冲销
  • 付款成功的钱怎么返还
  • 人工费没有发票怎么办
  • 研发费用的会计处理对公司经营成果的影响
  • 定额发票怎么领?
  • 工会经费返还属于什么收入
  • Excel导入Sqlserver数据库脚本
  • xp系统怎样设置无线网络连接
  • ubuntu lnmp环境搭建
  • windowsxp如何隐藏文件
  • 如何让电脑启动更快
  • windows7与xp
  • xp系统怎么隐藏文件
  • linux挂载cd
  • linux中chage命令
  • 摄像机跟随与摄像的区别
  • shell按行读取文件存入数组
  • 由浅入深易,由深入浅难
  • 功能强大的英语
  • js读取cookies
  • 安卓解析工具
  • javascript实现3D切换焦点图
  • 表单验证jquery
  • 电子税务局登录方式
  • 电信业务发票
  • 曲靖市国家税务局人员名单
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设