AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 787101
Accepted
Riccardo M.
Riccardo M.
Asked: 2016-07-01 01:20:55 +0800 CST2016-07-01 01:20:55 +0800 CST 2016-07-01 01:20:55 +0800 CST

使用 MyISAM 进行删除和插入后的 MySQL 行为和磁盘空间处理

  • 772

我对带有 MyISAM 引擎的 MySQL 在删除后处理空闲/空白空间的方式以及插入新记录时的行为有疑问。

例如,考虑一个新的空数据库(例如,假设是 10 kb)。

插入 10000 条记录后(假设每条记录占用 1 kb),它在文件系统上的总大小变为 10010 kb。

然后,在删除 5000 条记录后,即使记录数减半,它在文件系统上的大小仍为 10010 kb(这并不奇怪,这是正常行为)。

然后,OPTIMIZE 命令可以对数据库进行“碎片整理”,并通过重新组织其数据来回收可用空间。

但是,如果我完全忽略 OPTIMIZE 命令并插入 2000 条新记录(因此,仍然存在 5000 条 + 2000 条新记录 = 总共 7000 条记录),MySQL 是否会将先前删除留下的可用空间用于新记录(意味着10010 kb 的 DB 大小不会改变)还是将新记录“附加”到 DB(这意味着文件系统上的 DB 大小将增长到,比如说,12010 kb)?

谢谢!:)

mysql disk-space-utilization database myisam
  • 1 1 个回答
  • 593 Views

1 个回答

  • Voted
  1. Best Answer
    Janne Pikkarainen
    2016-07-01T04:32:32+08:002016-07-01T04:32:32+08:00

    通常,如果 MyISAM 表在 DELETE 操作之后在数据文件的中间有空闲空间,它将在该空闲空间中插入行。然而,由于 MyISAM 实现并发的方式,它取决于工作负载会发生什么。

    来自MySQL 手册

    对于有孔的表,如果它正在被另一个线程使用,则在表的末尾插入新行。否则,MySQL 会获取一个正常的写锁并将该行插入到孔中。

    甚至在微调该 concurrent_insert 参数之后。

    • 2

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve