博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
INDEX--关于索引的琐碎
阅读量:5905 次
发布时间:2019-06-19

本文共 903 字,大约阅读时间需要 3 分钟。

--=========================================================

更新时的操作
1>更新时有两种方式,一种是在原来的位置更新,另外一种是移除删除再插入。
2>无论采用何种方式更新数据,在触发器中都能使用DELETED和INSERTED表来获取更新前和更新后数据。

--=========================================================
--8亿数据创建非聚集索引时间
数据表中数据:873476300
建立索引耗时:41分39秒
索引键:BIGINT+DATETIME+INT
服务器配置:8核32G内存 7块SAS硬盘做成的RAID5,内存资源不足

--=========================================================
堆表和聚簇表测试
INSERT: 当数据库文件单次增长较小时,聚簇表插入效率会相对高,但当当数据库文件单次增长较大时,数据文件不需要频繁增长,堆表的插入效率略高于聚簇表。
SELECT/UPDATE/DELETE:聚簇表性能高于堆表(聚簇索引被使用时)
表无须额外增加过多空间来存放聚簇索引,只需少量空间存放非叶子节点

 

--=========================================================

DML操作在聚簇索引和非聚簇索引上的顺序
测试结论:
1>在插入数据时,先插入聚簇索引,再插入非聚簇索引
2>在更新数据时,先更新聚簇索引,再更新非聚簇索引
3>在删除数据时,先将非聚簇索引上数据MARK AS GHOST,然后再将聚簇索引上数据MARK AS GHOST,再删除聚簇索引上数据,最后移除非聚簇索引上数据

 

--=========================================================

数据的物理顺序和聚簇索引的顺序完全一致吗?
结论:在同一数据页上,数据的顺序和Slot的顺序一致,但数据不一定依次存放在依次递增的数据页上(逻辑碎片)

 

转载地址:http://uedpx.baihongyu.com/

你可能感兴趣的文章
[读书笔记]C#学习笔记一: .Net Framwork
查看>>
Fiddler工具的基本功能(转)
查看>>
使用 InstallShield limited edition 打包部署Outlook 2013 Office add-in插件
查看>>
@CentOS环境下Java开发环境的搭建
查看>>
关于云与持续集成杂谈
查看>>
Centos7 修改硬件时间和系统时间
查看>>
Selected SVN connector library is not available or cannot be loaded
查看>>
C# ComboBox自动完成功能的示例
查看>>
Java中的 List Set Map
查看>>
黄聪:css3实现图片划过一束光闪过效果(图片光影掠过效果)
查看>>
【转载】使用事件模型 & libev学习
查看>>
树莓派利用PuTTY进行远程登录
查看>>
rpm命令
查看>>
ASP.NET Core 折腾笔记二:自己写个完整的Cache缓存类来支持.NET Core
查看>>
arcgis api for js入门开发系列六地图分屏对比
查看>>
Spark Streaming基础概念
查看>>
Spring 4 官方文档学习(十一)Web MVC 框架之multipart(文件上传)支持
查看>>
Android 对Map按key和value分别排序
查看>>
设置ASP.NET MVC站点默认页为.html页 .
查看>>
Maven学习之 插件plugin
查看>>