位置: 编程技术 - 正文

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

  • 防伪税控系统
  • 增值税进项税是多少
  • 发票开具,发票备注栏能手写字吗?
  • 个体工商户单位性质怎么填
  • 税控盘必须一直插着吗
  • 接收商业承兑汇票需要到银行办手术吗
  • 增值税进项税额转出的账务处理
  • 事业基金弥补收支差额是什么意思
  • 货车挂靠企业需要交增值税吗?
  • 建筑工程地址
  • 进项税核定扣除试点
  • 增值税专用发票怎么开
  • 为什么增值税发票税率是1%
  • 退税差额怎么做账
  • 注册公司未签名怎么办
  • 税控技术服务费需要交印花税吗
  • 行政单位代管资金怎么做账
  • 银行流水账单怎么查
  • 1697508019
  • 补交前几年的进项发票
  • 企业所得税退税怎么做账务处理
  • macos15关闭sip
  • linux alias永久生效
  • 以房抵工程款会计分录
  • 未分配利润可留待以后年度进行分配的当年结余利润
  • dns进程
  • macOS Big Sur 11.2 RC 3(版本号20D64)预览版正式发布(附更新内容)
  • 金融行业如何征收营业税
  • 出租不动产增值税纳税义务发生时间
  • 销售折扣增值税如何处理
  • 基础知识讲解
  • php 单例模式优点及如何实现
  • 固定资产折旧的方法有几种
  • php实现5分钟倒计时
  • 股权置换和股权转让
  • web前端面试题最新
  • 编译和链接的区别是什么
  • vue获取当前行
  • yii框架教程
  • 货币资金有余额怎样填写清税申报表
  • 应收贷方表示啥
  • 固定资产报废如何记账
  • 购买加油卡如何做会计分录
  • 研发费用属于什么会计科目
  • wordpress 自动生成文章
  • 帝国cms灵动标签调用外表
  • 出口退税转内销还是转免税好
  • 所得税的应税所得额
  • 怎么在电子税务局查询进项发票
  • 合同不交印花税怎么处理
  • SQLServer 2008 Merge语句的OUTPUT功能
  • 解决PostgreSQL服务启动后占用100% CPU卡死的问题
  • 物流企业货损赔付标准
  • 营改增后,建筑行业与供应商签合同才怎样签没风险?
  • 企业所得税免税和减半征收
  • 对公账户的钱怎么用
  • 从农民手中购买粮食税率
  • 工业企业外购存货成本有
  • 个人所得税不允许核定的行业
  • 多缴所得税返还会计分录
  • 报废车收到的钱怎么做账
  • 科目汇总表一张几行啊
  • 债务抵消的构成要件
  • 公司网站维护费用计哪个科目
  • mysql5.7对应的jdbc
  • windows10 硬件
  • windows7/vista/server(no slic)
  • linux系统的介绍
  • WinXP巧用Netsh工具快速填写IP参数
  • win7系统的桌面图标怎么调出来
  • 3dmax创建图形怎么用
  • Android OpenGL ES(一)----必备知识
  • 注册表危险组件怎么安装
  • unity物理引擎原理
  • linux反弹shell方法
  • 小规模增值税减免会计科目
  • 2020年军人自主择业条件
  • 实木地板什么
  • 大疆小白控和普通控哪个信号好
  • 云南省昆明市税收优惠政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设