我的编程空间,编程开发者的网络收藏夹
学习永远不晚

索引与数据完整性的故事

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

索引与数据完整性的故事

    话说数据库也有着重要的衡量指标,那么性能和安全绝对是重要的两大板块,在这里性能指的是处理与响应户端服务的速度,而安全则是数据完整性规则。

    为啥要用索引?

        我们知道,当我们用select去查询一个表内容,或者用where指定一些关键字,Oracle会遍历整个表去寻找我们的数据,不会因为where找到了数据而不继续遍历,因为Oracle不知道是否数据表后面的字段有没有我们要的数据,所以还会遍历整个表数据,那么当一个大数据文件,是非常耗时的操作,为了提高我们的检索效率,更快速更高效的去找到我们想要的数据,也算是索引设计的初衷之一。

    索引怎样高效?

      为什么用力了索引就会高效,那么我们一起来了解一下索引的原理把,关系型数据库每一行都会有ROWID的,那么ROWID包括该行的条件、文件中的BOLACKS等,那么说到这里大概就知道!索引建立依靠ROWID来进行的,按照索引的村存储方法有B树的,还有位图索引。个人组织语言讲解这两种类型怕误人子弟引用百度知识!

    (1)B*树索引的存储结构类似书的索引结构,有分支和叶两种类型的存储数据块,分支块相当于书的大目录,叶块相当于索引到的具体的书页。Oracle用B*树机制存储索引条目,以保证用最短路径访问键值。默认情况下大多使用B*树索引,该索引就是通常所见的唯一索引、逆序索引。

    (2)位图索引存储主要用于节省空间,减少oracle对数据块的访问。它采用位图偏移方式来与表的行ID号对应,采用位图索引一般是重复值太多的表字段。位图索引之所以在实际密集型OLTP(联机事物处理)中用的比较少,是因为OLTP会对表进行大量的删除、修改、新建操作。Oracle每次进行操作都会对要操作的数据块加锁。以防止多人操作容易产生的数据库锁等待甚至死锁现象。在OLAP(联机分析处理)中应用位图有优势,因为OLAP中大部分是对数据库的查询操作,而且一般采用数据仓库技术,所以大量数据采用位图索引节省空间比较明显。当创建表的命令中包含有唯一性关键字时,不能创建位图索引,创建全局分区索引时也不能用位图索引。

    以上就是百度百科对两种结构的介绍

    格式:

        create index index_name on people(name)

    解释:

        那么index就是创建索引的关键字,这时候索引就会在表people列name上建立,会根据ROWID等信息把名字信息分块处理。

    通过本人测试不贴图了,对10W条数据进行测试,普通查找的COST的为400左右,当为某一列建立索引之后,4左右,效率100倍!

    DML的影响

     确实在检索方面很快,但是缺点无疑暴露,不适合频繁插入,更改删除等操作,为啥啊?因为当我们插入也会对索引进行修改,那么索引中不会把你修改删除的数据从块中清理释放内存,只是打上标记,而且有时候可能会改变“颠覆”原结构,重要的是不释放空间资源,所以我们在频繁插入修改删除的表中尽量避免索引这种机制,其次在数据量少的情况下也要去避免这种机制,因为小数据还要为索引建立格外开销,本身不具备什么优势。

    数据完整性(Data integrity)

     索引他就简单的说完了,谈谈数据的完整性,在前面很多章节都提到过数据的完整性,我们大多数认为就是数据比较完善就是数据的完整性,其实分的很精细,数据的完整性是指数据的可靠性和精确性.

     进一步的说,数据的完整性又分为实体完整性,参照完整,域完整性,用户自定义完整性四大类。

    实体完整性(Entity)

        简单来说,就是行的完整性,不能为空值,保证唯一性约束。那么通常用主键来保证实体的完整性,当主键有多列还会声明唯一性约束UNIQE来保证唯一标识。

    参照完整性 (Domain integrity)

                表与表之间的关系,对于父子表如果进行插入更新删除操作,只完成其中一个表就会破坏参照的完整性,字表为随着父表二变化,外键一般用来保证参照完整性的约束。

    域完整(Referential Integrity)

                域完整是指满嘴特殊的数据类型或者约束的列,比如check,not null,default等都在域完整的范围内。

    用户自定义完整(User-defined Integrity)

                用户自定义完整多数在用户对列中数据类型,字段的约束,比如我只想某一个字段插入什么样的内容,或者只允许插入1500元以下工资等等,根据我们的需求通过SQL语句动作得到预期的结果这个过程保证了我们自定义的完整,如CHECK检车约束的使用。

        更深入的知识这里不多做分享,怕误人子弟,以上是个人参照书籍资料加上自己的理解分享给大家的知识,不足之处希望指点出一定改进!



免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

索引与数据完整性的故事

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

数据的完整性

10.1什么是数据完整性作用:保证 用户的输入的数据 保存到数据库 是正确的比如:年龄:应该是数字,学号:应该是不重复的成绩:不能为空。 。 。怎么去保证数据的完整性:添加约束。完整性约束分类:实体(记录)完整性域完整性、引用完整性10.2实体完整性(行)实体
数据的完整性
2019-06-01

MySQL INSERT锁与数据库数据备份的完整性

在MySQL中,INSERT操作会加锁以确保数据的完整性。当一个INSERT操作执行时,MySQL会在表级别加上一个写锁,阻止其他会修改表结构或数据的操作,例如UPDATE、DELETE、ALTER TABLE等。这样可以保证数据的一致性和
MySQL INSERT锁与数据库数据备份的完整性
2024-08-13

PHP PDO 事务处理:确保数据完整性

PHP PDO 事务处理是一种强大的机制,可确保数据库操作的原子性和一致性。通过使用事务,您可以将一系列相关操作组合在一起,并保证要么所有操作都成功执行,要么都不执行。这对于维护数据完整性至关重要。
PHP PDO 事务处理:确保数据完整性
2024-02-17

如何确保数据与人工智能的完整性?

如果说数据是数字经济的新石油,那么人工智能(AI)就是蒸汽机。好似石油和蒸汽机为运输提供燃料,并推动工业革命一样,掌握数据与人工智能力量的公司同时也掌握着创新关键。

探索数据库同步的最佳实践:确保数据准确性和完整性

数据库同步在确保分布式系统中数据的一致性至关重要。本文探究了数据库同步的最佳实践,以提高准确性、完整性和性能。
探索数据库同步的最佳实践:确保数据准确性和完整性
2024-02-29

Java Hessian 是否能保证数据的完整性?(java hessian能保证数据的完整性吗 )

在Java开发中,Hessian是一种常用的远程调用协议,用于在不同的Java应用程序之间进行数据传输。然而,对于Hessian是否能保证数据的完整性,这是一个值得探讨的问题。Hessian是一种二进制序列化协议,它将Java对象序列化为二进制数据,并在网络
Java Hessian 是否能保证数据的完整性?(java hessian能保证数据的完整性吗  )
Java2024-12-17

Oracle数据库ODBC连接与数据备份完整性校验

Oracle数据库ODBC连接与数据备份完整性校验是数据库管理中非常重要的两个方面。ODBC连接是用来连接不同数据库系统的标准接口,可以让应用程序与数据库进行交互。而数据备份完整性校验则是确保备份的数据没有损坏或丢失。在Oracle数据库
Oracle数据库ODBC连接与数据备份完整性校验
2024-07-16

怎么保证Redis序列化数据的完整性与安全性

要保证Redis序列化数据的完整性与安全性,可以采取以下措施:使用合适的序列化机制:选择合适的序列化机制可以确保数据的完整性和安全性。常见的序列化机制包括JSON、MessagePack、Protobuf等,可以根据具体需求选择最适合的序列
怎么保证Redis序列化数据的完整性与安全性
2024-04-29

PHP与数据库完整性集成的方法是什么

这篇文章主要介绍“PHP与数据库完整性集成的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PHP与数据库完整性集成的方法是什么”文章能帮助大家解决问题。数据完整性概述数据完整性是指数据库中
2023-07-06

编程热搜

目录