位置: 编程技术 - 正文

理解Sql Server中的聚集索引(解释sql server实例)

发布时间:2024-02-26

推荐整理分享理解Sql Server中的聚集索引(解释sql server实例),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server概述,简述sql server,sql server原理,简述sql server,sql server概述,理解什么是sql server,sql的理解,解释sql server实例,内容如对您有帮助,希望把文章链接给更多的朋友!

  说到聚集索引,我想每个码农都明白,但是也有很多像我这样的猥程序员,只能用死记硬背来解决这个问题,什么表中只能建一个聚集索引,然后又扯到了目录查找来帮助读者记忆。。。。问题就在这里,我们不是学文科,,,不需要去死记硬背,,,我们需要的就是能看到在眼里面的真实东西。。。。。我们都喜欢聚集索引,因为它能够把无序的堆表记录变成有序,还玩起了B树。。。这样就把复杂度从N降低到了LogMN。。。

这样的话逻辑读,物理读就下来了。

一:现象

1:无索引的情况

  还是老规矩,看个例子感受下,首先我有一个Product表,里面没有任何索引,如下图:

从上图中,我悲剧的看到了,物理读是9次,也就说明走了9次硬盘,你也可以想到,走硬盘的目的是为了拿数据,逻辑读有次,要注意的是这里的”次“是“页”的意思,也就是在内存中走了个数据页,我用dbcc ind 给你看一下,是不是有个表数据页。

这里有个数据页的原因是第一个是IAM跟踪页。

2:有聚集索引的情况

下面我在Product表中建一个product_idx_productid的聚集索引,然后再次看看io情况,如下图:

当你看到这个”逻辑读“为3次的时候,你是不是已经疯了。。。在多达个数据页中找到目标数据,只需3次。。。。这个在算法盲看来是不是神

仙下凡???当然,,,此物天上有,人间也有。。。既然有,就应该有一种非常强烈的探索欲。。。。看看这里面到底是怎么玩的。。。。。。

二:探索原理

1:探索叶子节点

  刚才也说了,聚集索引玩的就是B树,既然是B树,那就有叶子节点和分支节点,专业术语就是度为0的为叶子节点,度>0的叫做分支节点。。。。

我想你也听说了,聚集索引是将索引列数据进行排序后放入B树,那为了让你眼见为实,我先建立一个ID无序的3条记录。

然后我用dbcc ind 命令查看下3条记录在哪个数据页中,如图:

从图中可以看到,我的三条记录是放在号数据页中的,然后我导出号数据页,看看内容是什么。

从上图中,我们看到了”数据页“中的各个槽位的指向是按照表中的实际存储记录来的,好了,下面我创建个聚集索引,看看实际数据是不是真的有序了?

理解Sql Server中的聚集索引(解释sql server实例)

不过在这里有个有趣的问题,我的号”表数据页“哪去了???也是够奇葩的,换来的确实号索引页,那为了保证数据完整性,应该是把号数据页的内容灌到索引页里面去了吧???? 没关系,验证一下。

通过上面的图,有没有直观的感觉到? 数据现在已经是aaaaa,bbbbb,ccccc的模式了。。。有序啦。。。。同时索引页中也保存了号数据

页的字段值,比如ID,Name信息,拿下面的slot0槽位举例:

到此为止,我想你对叶子节点的内容有了个大概的认识,起码没有让你死记硬背了~~~

2 :探索分支节点

  为了让你看到分支节点,我得多灌一些数据进去,好歹要让数据撑破一个索引数据页,这样分支节点索引数据页就出来了,看下面的例子:

从图中可以看到,当我插入条数据的时候,已经出现了一个分支节点(号索引数据页),三个叶子节点(,,),叶子

节点的数据页内容我也说过了,现在我很好奇”分支节点“中保存着什么内容???我好兴奋,我要导出号索引数据页了。。。

简单分析下slot0: ad 的内容

:叶子索引页中的最小key值(这里有点特殊,除一行记录不是保存最小值以外,其余都是的),转换为十进制就是0。

ad:叶子索引页的页号,转换为十进制就是。

:叶子索引页的文件号,转换为十进制就是1.

不过通过分析,我们看到了,其实分支节点中保存着有两个值,一个childpage的minkey,一个childpage的pageid,同理,其他的槽位也是这样。

我们换个参数命令,让结果更直观点,记录中就是保存着”pageID“和”minKey“。

这样的话,我脑海中就有一张图出来了,不知道你现在是否有了????

通过上面的分析,除了第一行记录不是保存子索引页中最小key的值外,其他记录都是提取子索引页中的最小索引键值,这一点要注意。。。

也许对sqlserver团队来说,只要判断小于的话就直接去(1:)数据页,小于的直接去(1:)数据页就可以啦。。。

当你看到这里的时候,不知道你是否已经明白,为什么表中只能有一个聚集索引呢???好了,乱鸡巴扯了好多,希望对你有所帮助。

Sql Server中的非聚集索引详细介 非聚集索引,这个是大家都非常熟悉的一个东西,有时候我们由于业务原因,sql写的非常复杂,需要join很多张表,然后就泪流满面了。。。这时候就有D

Sql Server中的DBCC命令详细介绍 今天研发中心办年会,晚上就是各自部门聚餐了,我个人喜欢喝干红,在干红中你可以体味到那种酸甜苦辣。。。人生何尝不是这样呢???正好ceo从

SQL Server中将查询结果转换为Json格式脚本分享 脚本源码:SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGOCREATEPROCEDURE[dbo].[SerializeJSON](@ParameterSQLASVARCHAR(MAX))ASBEGINDECLARE@SQLNVARCHAR(MAX)DECLARE@XMLStringVARCHAR(MAX)DECLARE@XMLXMLDECLA

标签: 解释sql server实例

本文链接地址:https://www.jiuchutong.com/biancheng/347768.html 转载请保留说明!

上一篇:深入理解Sql Server中的表扫描(深入理解中国式现代化论文)

下一篇:Sql Server中的非聚集索引详细介(sql中的非逻辑)

  • PHP多进程编程之僵尸进程问题的理解(php多进程开发)

    PHP多进程编程之僵尸进程问题的理解(php多进程开发)

  • SQL注入全过程深入分析(sql注入的原理和步骤)

    直接通过Google浏览器就能去除。

    点击登录,返回的信息如下:

    Conversion failed when converting the nvarchar value 'master' to data type int.

    数据库名称“master”通过异常被显示出来!依次改变上面SQL语句中的序号,

    就能得到服务器上所有数据库的名称。

    接着,输入信息如下:

    得到返回信息如下:

    Conversion failed when converting the nvarchar value 'spt_fallback_db' to data type int.

    我们得到了master数据库中的第一张表名:“spt_fallback_db”,

    同上,依次改变序号,可得到该库全部表名。

    现在我们以“spt_fallback_db”表为例,尝试获取该表中所有的字段名。在输入框中输入以下代码:

    于是,得到错误提示如下:

    "Conversion failed when converting the nvarchar value 'xserver_name' to data type int." class="img-responsive" alt="SQL注入全过程深入分析(sql注入的原理和步骤)">

    SQL注入全过程深入分析(sql注入的原理和步骤)

  • SUN常用系统维护命令(系统维护的主要内容有哪些)

    SUN常用系统维护命令(系统维护的主要内容有哪些)

  • Windows 注册表LastKey键值的设置技巧(windows 注册表命令)

    Windows 注册表LastKey键值的设置技巧(windows 注册表命令)

  • Win xp死亡倒计时工具如何下载安装教程(附xp死亡倒计时小工具下载)(windows xp死亡倒计时)

    Win xp死亡倒计时工具如何下载安装教程(附xp死亡倒计时小工具下载)(windows xp死亡倒计时)

  • 电脑没有声音了 Win8音频服务未运行的解决办法(电脑没有声音了是怎么回事)

    电脑没有声音了 Win8音频服务未运行的解决办法(电脑没有声音了是怎么回事)

  • 使用Python脚本和ADB命令实现卸载App(pythoni脚本)

    使用Python脚本和ADB命令实现卸载App(pythoni脚本)

  • 详解JavaScript基于面向对象之创建对象(1)(js基础)

    详解JavaScript基于面向对象之创建对象(1)(js基础)

  • 认证不过的进项税是怎么调出分录?
  • 营业外收入做销项税调整
  • 会计为什么要计折旧费
  • 开户行为什么是中国建设银行总行
  • 贷款利息收入的税率是多少
  • 现金余额大违反了什么规定
  • 多计提以前年度损益调整账务处理怎么做
  • 管理费用现金流量表中属于
  • 运费成本会计分录
  • 房地产企业汇算清缴报表
  • 上海房产税如何退税
  • 开专票还需要提供营业执照?
  • 什么叫含税级距和不含税级距
  • 劳务费发票税率是多少
  • 财税[2001]10号
  • 专票和普票的税率哪个高
  • 股东借款可以转为认缴出资
  • 固定资产清理净值是什么意思
  • php中面向对象
  • 出租的土地
  • 增值税中的筹划方法哪些可以应用在消费税中,为什么?
  • kwhcommonpop.exe是什么程序
  • 便秘怎么办 女性
  • sci期刊投稿步骤
  • js设置input值
  • coco2017数据集介绍
  • 应付账款重分类含不含暂估
  • 免征增值税会计科目
  • 真题解析买谁的
  • springboot+chatgpt+chatUI Pro开发智能聊天工具
  • 管理费用增加记哪方
  • pnpnpn的工作原理
  • 预收账款什么时候确认增值税
  • 企业年金举例说明
  • 工程项目工资表
  • 民办非企业收到政府拨款分录
  • 坏账核销的会计规定
  • 无形资产的摊销年限及摊销方法
  • 资产处置损益和投资收益的区别
  • 核定征收的情况包括
  • 房地产企业成本包括哪些
  • 主营业务收入多计提怎么冲减
  • 商场返券计算公式
  • 还银行贷款如何计算利息
  • 资金周转率计算公式
  • 冲销主营业务收入怎么做分录
  • 土地使用权作为存货怎么入账
  • 被代持股份的股东需要负责吗
  • 留底税额怎么入账
  • 样品定义是什么
  • 税交多了可以退吗
  • 从事小额零星经营业务的个人,其支出
  • 费用分析的作用
  • 公司电子发票报销
  • 会计记账凭证怎么装订视频
  • mysql经典书
  • 调整后视镜
  • 如何动态修改mysql的全局参数
  • sql server发布
  • mysql基本教程
  • linux系统简介
  • win8怎么禁止弹窗
  • win10红石版
  • 登录ip怎么查位置
  • windows7电脑无法正常运行
  • Win10预览版桌面图标和任务栏不翼而飞怎么办?
  • win10正式版激活码
  • android怎么ping
  • node.js报错
  • unity2d的小游戏
  • unity怎么弄游戏小地图
  • jquery 图片插件
  • shell脚本语句
  • 基于JAVASCRIPT实现的可视化工具是
  • jquery 获取父元素的子元素
  • jquery iframe
  • 中央与地方增值税
  • 成品油消费税税率2023
  • 安徽国家税务局增值税发票查询平台
  • 车辆购置税如何入账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号