位置: 编程技术 - 正文

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

  • 银行存款支付是借还是贷
  • 小规模没有计提增值税直接缴纳了
  • 出纳取备用金需要交税吗
  • 销售方记账凭证怎么做分录
  • 房地产企业回迁房增值税
  • 销售企业资金风险点有哪些呢
  • 个税申报包含哪些
  • 不能够满足标准的产品为不合格品
  • 临时工人工资原始凭证怎么做及会计分录解析?
  • 水利事业单位基建并账分录怎么写?
  • 销售额增加10%什么概念
  • 增值税专用发票有效期是多长时间
  • 出口公司要交哪些税费
  • 主营业务收入是营业收入吗
  • 企业支付宝可以转账到对公账户吗
  • 外包物流适用范围
  • 季度申报的小规模纳税人怎么查看销售额达到500万
  • 以前的纳税申报表还能打印吗
  • 月销售不超过10万免征哪些税
  • 收到安监处罚款怎么处理
  • 防疫物资费用会计处理
  • 什么是CMOS什么是BIOS
  • system idle process是什么进程(CPU的空闲率)
  • 商会收到的会费要交企业所得税
  • element-plus vue
  • 进项税额转出会造成增值税应纳税额
  • msmpeng.exe是什么进程
  • map程序
  • PHP:zip_entry_compressedsize()的用法_Zip函数
  • 社会保险费缓缴政策
  • 因质量问题收取停工通知
  • 广告费业务宣传费可以结转吗
  • 长期借款和实收资本
  • 销售退换货的账务处理
  • 企业汇算清缴发现之前收入记多了可以调整吗
  • 增值税专用发票查询系统官方网站
  • html 教程
  • 支付职工差旅费发生的现金流出
  • 安全文明措施费费率一般为多少
  • 织梦遍历栏目描述
  • mysql 子查询
  • Python可变数据类型和不可变数据类型
  • 已经抵扣的发票红字信息表怎么开
  • 工业企业库存商品的初始入账成本
  • 怎么计算利润的百分比
  • 员工意外伤害保险最多赔多少
  • 以设备投资入股的账务处理
  • 在建工程发生的运费计入什么科目
  • 出售无形资产净损失
  • 转账支票怎么填写会计凭证
  • 发票上的数量怎么填写
  • 工会经费的减除项是什么
  • 明细账设置是什么意思
  • win7系统怎么设置开机启动项
  • xp系统玩游戏卡吗
  • windowsxp错误提示
  • xp系统的输入法在哪里设置
  • keyemain.exe是什么进程
  • linux的收获
  • windows10虚拟桌面
  • 2021年win10累积更新
  • win10qq在哪里启动
  • node的fs模块
  • jquery animation
  • 教你在heroku云平台上部署Node.js应用
  • 对于javascript理解
  • 支持向量机
  • 基于jQuery实现Tabs选项卡自定义插件
  • android contextmenu
  • python遍历文本的每条数据
  • adb工具使用说明文档下载
  • 税务局纳税服务中心
  • 税务稽查为什么不问证人
  • 衡水地税局税务电话
  • 陕西省国家税务总局电子税务局
  • 张雪峰谈建筑专业
  • 公司购买的汽车可以一次进入费用吗
  • 国家税务总局可以设定行政处罚吗
  • 广州市地方税务局 社保费申报
  • 关于啤酒包装物押金,下列正确的是( )
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设