位置: 编程技术 - 正文

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个税点怎么计算公式
  • 美团代金券是抵用券吗
  • 工商公示纳税总额包含个税吗
  • 航空运单能当发票使用吗
  • 支付境外特许权所得需要交什么税
  • 二类经适房转商品房需要交多少钱
  • 权益法下被投资企业净资产增加
  • 增值税组成计税价格包括消费税吗
  • 税务评估补税如何入账处理合适?
  • 应收账款少收的款分录
  • 关联方往来款项余额
  • 一般纳税人税率2023
  • 增值税发票抵扣勾选平台如何操作
  • 搬迁到新租赁厂房的费用入什么科目?
  • 公司产品中请别人开发的软件怎么会计处理?
  • 税率13降到11的财税政策解读
  • 个税返还手续费入什么科目
  • 增值税抄税报税流程2021
  • 家具螺丝螺母一般在哪里卖
  • 6月 全新windows
  • 华为正式发布鸿蒙官网
  • linux中的util值很高
  • 或有事项的计量结束语
  • 施工企业临时设施属于
  • 包装物押金为什么含税
  • 工业危废处理的前景
  • 会计核算的一般对象
  • windows11蓝牙问题
  • php版本常用的排版软件
  • os x yosemite dp5下载地址 os x 10.10 dp5更新内容
  • windows 7怎么打开虚拟化
  • 销售商品收到商业汇票一张会计分录
  • 公司多缴税款了怎么办?可以退吗?
  • dwm.exe是啥
  • 买了土地没有土地证怎么办理
  • 任意公积金可以不提取吗
  • php实现登录功能
  • 金融机构拆出资金的最长期限
  • 特殊动产的一物数卖履行顺序
  • 增值税报税后多久缴纳期限
  • 增票的纳税人识别号是啥
  • python字典怎么添加值
  • 哪些固定资产不能计提折旧
  • 反写必须15号之前吗
  • 物价变动的影响因素
  • 企业不年报会怎么样
  • 其他应收账款为个人借款
  • 免税增值税纳税申报表怎么填
  • 为什么分红不影响损益
  • 持有至到期投资属于什么科目
  • 资产负债表的货币资金怎么算
  • 小企业会计准则主要按照什么计量
  • mysql select语句操作实例
  • 一般纳税人季报怎么填
  • 工程分包合同协议书
  • 长期应收款的主要类型
  • 开出地税发票(工程款)怎么做账?
  • 重大水利工程建设
  • 商誉的算法
  • 合作社盈余返还总额是指哪些数据
  • 预缴税款的会计处理
  • 其他综合收益包括留存收益吗
  • 利润表每股收益增加说明什么
  • sql怎么遍历
  • Navicat for MySQL导出表结构脚本的简单方法
  • sql取汉字
  • 电脑windows8怎么样
  • win10正式版多少钱
  • android开发地图应用
  • nodejs webapp
  • unity资源包管理器
  • jquery escape
  • shell脚本检查输入参数
  • python设计gui
  • 税务局上下班路上能穿制服吗
  • 武汉税务局官网查询系统
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设