码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据库系统原理与实践 笔记 #9


    文章目录

    • 数据库系统原理与实践 笔记 #9
    • 存储管理与索引
      • 文件和记录的组织
        • 文件组织
        • 定长记录
        • 变长记录
        • 分槽的页结构
        • 文件中记录的组织
        • 顺序文件组织
        • 多表聚簇文件组织

    数据库系统原理与实践 笔记 #9

    存储管理与索引

    文件和记录的组织

    文件组织

    • 数据库是以一系列文件的形式存储的。每个文件再逻辑上组织称为记录的一个序列:
      • 每个文件分为定长的存储单元,称为块(block)
      • 块是存储分配和数据传输的基本单元,块大小一般为4~8KB

    定长记录

    • 简单方案:
      • 记录i从第 n × ( i − 1 ) n\times (i-1) n×(i−1)个字节开始存储,n是每个记录的大小
      • 访问记录很简单,但是一个记录可能存储于不同块,假设要求:不允许记录跨过块边界,没有记录是部分包含在一个块中
    • 删除第i个记录的可选方案:
      • 将记录i+1,…,n移动到i,…,n-1
      • 将记录n移到i
      • 不移动记录,在一个空闲列表中将所有空闲记录列出

    变长记录

    • 变长记录以下面几种方式出现在数据库系统中:
      • 多种记录类型存储在一个文件中
      • 允许一个或多个字段是变长的记录类型
      • 允许可重复字段的记录类型
    • 属性按照顺序存储
    • 以固定大小表示可变长度的属性(偏移量、长度),实际数据存储在所有固定长度的属性后
    • 记录末尾加上记录终止符
      在这里插入图片描述

    分槽的页结构

    • 分槽页的块头包含:
      • 块中记录条目的个数
      • 块中空闲空间的末尾处
      • 一个由包含记录位置和大小的记录条目组成的数组
    • 记录可以在页中移动,来保持它们的连续存储
    • 记录相互间没有空闲的空间(若删除记录,需移动记录数据)

    文件中记录的组织

    • 如何在文件中组织记录:
      • 堆文件组织:一个记录可以存放在文件中的任何地方,只要那个地方有空间存储这条数据
      • 顺序文件组织:记录根据“搜索码”的值顺序存储
      • 散列文件组织:在每条记录的某些属性上计算一个散列函数,散列函数的结果确定记录应放到文件的哪个块中
    • 通常,每个关系的记录用一个单独的文件存储
    • 但是多表聚簇文件组织中,几个不同关系的记录存储在同一个文件中:目的在于同一块中存储相关记录,以将I/O代价减到最小

    顺序文件组织

    • 使用于需要对整个文件进行顺序处理的应用
    • 文件中的记录按搜索码排序
    • 删除 - 使用指针链
    • 插入 - 定位插入的位置:
      • 如果有空闲空间,那么插入到空闲处
      • 如果没有空闲空间,将新纪录插入到溢出块
      • 无论哪种方式,指针链都要更新

    多表聚簇文件组织

    • 用多表聚簇文件组织在一个文件中存储多个关系
    • 能够很好地处理对 d e p a r t m e n t ⋈ i n s t r u c t o r department\bowtie instructor department⋈instructor的查询以及涉及一个系和相应老师的查询
    • 对只设计department的查询效果不好
    • 可以添加指针链来链接某个关系的记录
  • 相关阅读:
    python爬取公众号之 创建个人微信公众号
    【OpenCV学习】第6课:图像模糊(中值滤波,高斯双边滤波)
    Jenkins 重新定义 pom 内容,打包
    基于x86架构的CentOS7虚拟机通过qemu安装ARM架构CentOS7虚拟机
    【调试经验】MySQL - fatal error: mysql/mysql.h: 没有那个文件或目录
    5.3 Web服务器简介及HTTP协议
    基本的UDP套接字编程
    Struts.xml 配置文件说明
    API调用,淘宝天猫、1688、京东、拼多多各平台获得淘宝商品详情
    二分查找:如何用最省内存的方式实现快速查找功能?
  • 原文地址:https://blog.csdn.net/qq_40029067/article/details/134509871
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号