- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个由大量 blob 组成的表,我想对其进行一些测试。
我知道删除的空间不会被 innodb 回收,所以我决定通过更新它自己的值而不是创建新记录来重用现有记录。
但我注意到,无论是删除和插入新条目,还是对现有 ROW 进行更新,InnoDB 都在不断增长。
假设我有 100 行,每行存储 500KB 的信息,我的 InnoDB 大小是 10MB,现在当我对所有行调用 UPDATE(无插入/无删除)时,innodb 每次运行都会增长约 8MB。我所做的只是在每一行中存储恰好 500KB 的数据,几乎没有修改,并且 blob 的大小是固定的。
我能做些什么来防止这种情况发生?
我知道优化表,但我做不到,因为在正常使用情况下,该表将有 60-100GB 大,运行优化只会使整个服务器停止运行。
最佳答案
But I noticed, whether I delete and insert a new entry, or I do UPDATE on existing ROW, InnoDB keeps on growing.
InnoDB
是一个多版本系统。
这意味着每次更新或删除一行时,该行的先前版本都会被复制到一个称为回滚段
的特殊位置。原始记录被新数据重写(在 UPDATE
的情况下)或标记为已删除(在 DELETE
的情况下)。
如果您执行事务回滚或执行并发 SELECT
语句(由于新版本尚未提交,因此必须查看以前的版本),从 rollback 中检索数据段
。
问题在于 InnoDB
表空间从不收缩。如果表空间已满,则分配新空间。已提交事务的回滚信息占用的空间也可以重复使用,但如果表空间已满,它将被扩展,这是永久性的。
除了备份整个数据库、删除并重新创建 InnoDB
文件以及从备份中恢复之外,没有支持的方法来缩小 ibdata*
文件。
即使您使用 innodb_file_per_table
选项,回滚表空间仍存储在共享的 ibdata*
文件中。
但是请注意,表占用的空间和表空间占用的空间是不同的东西。可以通过运行 OPTIMIZE
来缩小表,这将使它们更紧凑(在表空间内),但表空间本身不能缩小。
关于mysql - 为什么 InnoDB 在没有每次更新的情况下继续增长?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4546294/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!