位置: 编程技术 - 正文

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

  • 来料加工与进料加工的相似之处有
  • 不予认定一般纳税人
  • 应纳税所得额是什么意思
  • 税务uk开票人显示是管理员怎么改
  • 没有进项发票出口转内销
  • 报销招待费事由有哪些
  • 单用途卡与多用途卡
  • 政府基金如何开票
  • 如何规范填写费用表格
  • 退回投标保证金分录
  • 企业因购买材料开出的商业汇票属于什么会计科目
  • 未认证发票先入账可以吗
  • 退货应入会计什么科目
  • 内账的成本结转含税还是不含税?
  • 支付给供应商的现金属于什么活动
  • 处置其他权益工具投资会影响当期损益吗
  • 安置房视同销售需要缴纳所得税吗?
  • 呆账怎么写会计分录
  • 所得税申报怎么弥补以前年度亏损
  • 想用u盘装系统怎么弄
  • php过滤数组中的空字符串
  • 飞机电子普通发票6%税率可以抵扣吗
  • php与mysql基础教程
  • PHP:spl_object_hash()的用法_spl函数
  • 代开发票的弊端?
  • php输出流
  • 代理金融业务
  • 异地银行结算账户的特点
  • 企业取得的搬迁补贴
  • 长期应收款属于流动资产吗
  • 对外支付佣金需要扣缴所得税吗
  • jquery制作轮播切换效果
  • 新成立公司建账
  • gridview功能
  • [Vue warn]: Error in render: “TypeError: Cannot read properties of undefined(reading“category1Name“
  • 图像可以分成哪些类别?
  • 目标检测选SSD还是YOLO
  • opencv讲解
  • 麻雀优化算法和鲸鱼算法哪个好
  • php die exit
  • php yield 异步
  • inotify_event
  • 对公账号里面的钱会扣税吗
  • 施工企业的人工费占比
  • 发票认证系统叫什么名字
  • 收到费用报销单据应该怎么记账?
  • 增值税会计账务处理例题
  • 经审计的财务报表是否要会计师事务所盖章
  • 执行企业会计制度是什么意思
  • 小微企业应纳税所得额100万到300万怎么计算
  • 过次页是本页合计吗
  • 营改增后建筑企业税负
  • 费用报销单如何粘贴票据
  • 交通运输行业指什么
  • 生产成本结转到本年利润吗
  • 事业单位收入是再分配吗
  • 营业外收入主要来源
  • win2008安装sql2005
  • 重装Windows11
  • SUSE Linux Enterprise Server 设置IP地址、网关、DNS的方法
  • mac电脑安装软件未受信任
  • winxp不能正常启动
  • 水下摄影技巧
  • dos命令批处理
  • 局域网扫描器
  • python的文件操作中找不到文件应该如何处理
  • 面向对象实例化
  • opengl transform
  • 微信小程序支付的钱怎么退款
  • node.js中实现同步操作的3种实现方法
  • 用nodejs做的项目
  • bat中if语句的用法
  • Node.js中的construct构造函数
  • 基于flask框架
  • 利用js脚本模拟鼠标点击事件
  • js md5加密方法
  • 企业所得税汇总纳税备案表
  • 社保当月减员当月还可以增加上吗
  • 纳税服务投诉工作要求
  • 税务上门核查要看什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设