返回顶部
首页 > 资讯 > 数据库 >索引与数据完整性的故事
  • 345
分享到

索引与数据完整性的故事

2024-04-02 19:04:59 345人浏览 八月长安
摘要

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

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

    为啥要用索引?

        我们知道,当我们用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检车约束的使用。

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



您可能感兴趣的文档:

--结束END--

本文标题: 索引与数据完整性的故事

本文链接: https://lsjlt.com/news/42666.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 索引与数据完整性的故事
        话说数据库也有着重要的衡量指标,那么性能和安全绝对是重要的两大板块,在这里性能指的是处理与响应户端服务的速度,而安全则是数据完整性规则。  &nbs...
    99+
    2024-04-02
  • 数据的完整性
    10.1什么是数据完整性 作用:保证 用户的输入的数据 保存到数据库 是正确的 比如: 年龄:应该是数字, 学号:应该是不重复的 成绩:不能为空 。 。 。 怎么去保证数据的完整性:添加约束。 完整性约束分类: 实体(记录)完整性 域完整...
    99+
    2019-06-01
    数据的完整性
  • MySQL--数据完整性
    - 数据类型 原则 尽量使用取值范围小的,节省存储空间 整数:int, bit  小数:decimal  表示浮点数  decimal(5,&nb...
    99+
    2024-04-02
  • 关系数据库的完整性约束:实体完整性、参照完整性、用户自定义完整性
    关系模型的三种完整性约束是实体完整性、参照完整性和用户定义完整性。 文章目录 关系模型的三种完整性约束是实体完整性、参照完整性和用户定义完整性。实体完整性参照完整性用户自定义完整性 ...
    99+
    2023-10-03
    mysql sql
  • 数据完整性的基石:主键与外键
    ...
    99+
    2024-04-02
  • PHP PDO 事务处理:确保数据完整性
    什么是事务处理? 事务处理是数据库系统中一种重要的概念,它提供了一种机制,用于确保一组操作要么全部执行成功,要么都不执行。在事务开始时,数据库将创建一个保存点,以记录事务开始时的数据库状态。 PDO 事务处理 PDO(PHP Data ...
    99+
    2024-02-17
    PHP PDO 事务 处理 数据完整性
  • Python ORM 中的事务管理:确保数据完整性
    事务的特征: 原子性 (Atomicity):事务中的所有操作要么全部提交,要么全部回滚,不存在部分提交的情况。 一致性 (Consistency):事务完成后,数据库必须处于一致状态,符合所有约束条件和完整性规则。 隔离性 (Isol...
    99+
    2024-03-15
    ORM
  • Python与大数据:索引与异步编程的完美结合
    随着大数据时代的到来,数据处理已经成为了企业和个人必备的技能。而Python作为一种流行的编程语言,在大数据领域也表现出了强大的能力。本文将介绍Python在大数据中索引和异步编程的应用,以及如何将它们结合起来,提高数据处理效率。 一、索...
    99+
    2023-08-04
    索引 异步编程 大数据
  • 打包Java项目,如何保证索引完整性?
    在Java开发中,我们经常需要将项目打包成可执行的jar包或war包,以便于部署和运行。在打包过程中,我们需要考虑到jar包中包含的索引文件是否完整,因为索引文件的完整性直接影响着程序的运行效率和正确性。本文将介绍如何打包Java项目,并...
    99+
    2023-06-18
    索引 打包 缓存
  • 数据库完整性检查
    为了主动发现数据库侧页损坏,保证数据库逻辑和物理完整性,计划每周六上午6点,针对生产主库上的所有系统和用户数据库执行DBCC CHECKDB,将结果记录到表中。以下为理论依据:SQL Server数据库可以...
    99+
    2024-04-02
  • MySQL与PHP的基础与应用专题之数据完整性
    目录概述数据完整性实体完整性域完整性参照完整性自定完整性唯一性外键创建主表&从表插入数据错误展示概述 从今天开始, 小白我将带领大家一起来补充一下 数据库的知识. 数据完整...
    99+
    2024-04-02
  • MySQL的索引与事务
    作者:敲代码の流川枫 博客主页:流川枫的博客 专栏:和我一起学java 语录:Stay hungry stay foolish 给大家推荐一款好用的神器Apifox = Postman + Swagger + Mock + JMeter。集...
    99+
    2023-09-01
    数据库 java mysql
  • 探索数据库同步的最佳实践:确保数据准确性和完整性
    1. 选择合适的复制技术 根据业务需求和系统架构,选择最合适的复制技术。异步复制适用于需要高可用性的场景,而同步复制则在要求强一致性的情况下更合适。 演示代码: -- 异步复制 CREATE PUBLICATION my_publica...
    99+
    2024-02-29
    数据库同步 数据一致性 数据准确性 数据完整性 数据库复制
  • Oracle数据库ODBC连接与数据备份完整性校验
    Oracle数据库ODBC连接与数据备份完整性校验是数据库管理中非常重要的两个方面。ODBC连接是用来连接不同数据库系统的标准接口,可以让应用程序与数据库进行交互。而数据备份完整性校验则是确保备份的数据没有损坏或丢失。 在Oracle数据库...
    99+
    2024-07-16
    oracle
  • 怎么保证Redis序列化数据的完整性与安全性
    要保证Redis序列化数据的完整性与安全性,可以采取以下措施: 使用合适的序列化机制:选择合适的序列化机制可以确保数据的完整性和...
    99+
    2024-04-29
    Redis
  • MySQL数据库的索引和事务
    一、前言本文将要详细介绍MySQL索引与事务的概念及原理,并初步了解MySQL数据库视图概念,简述数据库的存储过程。二、索引2.1索引的概念——什么是索引一般来说,一篇论文,或者说一本书,都有其目录,而目录...
    99+
    2024-04-02
  • PHP开发者必看:使用path和numy索引优化索引性能的完整指南!
    在PHP开发中,索引是一个非常重要的概念。它可以帮助我们快速地访问和操作大量数据,提高程序的性能和效率。但是,如果我们的索引设计不合理,会导致程序性能下降甚至崩溃。因此,本文将介绍如何使用path和numy索引来优化索引性能。 一、pat...
    99+
    2023-10-01
    path numy 索引
  • MySQL数据库高级(一)——数据完整性
    MySQL数据库高级(一)——数据完整性 一、数据完整性简介 1、数据完整性简介 数据冗余是指数据库中存在一些重复的数据,数据完整性是指数据库中的数据能够正确反应实际情况。数据的完整性是指数据的可靠性和准确...
    99+
    2024-04-02
  • PHP与数据库完整性集成的方法是什么
    这篇文章主要介绍“PHP与数据库完整性集成的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PHP与数据库完整性集成的方法是什么”文章能帮助大家解决问题。数据完整性概述数据完整性是指数据库中...
    99+
    2023-07-06
  • MySQL数据完整性的示例分析
    这篇文章主要介绍MySQL数据完整性的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!数据完整性分为:实体完整性,域完整性,参考完整性。参考完整性:参照完整性指的就是多表之间的...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作