- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习如何通过为列重新选择正确的数据类型来优化我的数据库,我想知道如果我选择 MEDIUMINT
(3 字节)而不是我会节省多少大小INT
(4 字节)
AFAIK - 如果我错了请纠正我 - 我需要数据库大小尽可能小以适应 RAM 以减少硬盘请求。数据库的大小由表大小+索引大小组成
假设我有一个 INT
列,其中有 10'000'000 行和一个 B-Tree 索引,如果我更改列的数据类型,我将节省多少 MB从 INT
到 MEDIUMINT
在
注意:我知道 MySQL 不会减少磁盘上的实际大小,除非我 OPTIMIZE TABLE
编辑:我的情况是,我将很快完成我生命中的第一个严肃系统 - 这是一个我计划在阿拉伯地区市场销售的 ERP 系统 - 。计划 1、2、3、4 数据库应该分别约为 2GB、4GB、10GB、40GB,所以如果我可以在不牺牲性能/功能的情况下减小每个数据库的大小,为什么不呢?如果我可以让一台 32GB RAM 的机器为 4 个客户端而不是 2 个客户端提供服务,为什么不呢?
最佳答案
除非您有特定的、可衡量的问题,否则请使用INT
。在这个时代,即使是最节俭的智能手机也有十亿个字节用于内存,如果你为每个字节烦恼,你只会把事情弄得一团糟。
I need the database size to be as small as possible to fit in RAM to reduce the hard-desk requests.
不,你不知道。您需要数据库易于使用并充分地执行。在以 SSD 为后盾的数据库时代,I/O 不会成为问题,除非您进行大规模操作,如果那一天到来,那么您可以进行测量并了解您遇到的具体问题。
从 INT
字段中去除一个字节不太可能使任何事情变得更好,因为三字节整数值不是您的 CPU 可以直接处理的东西。这些将被转换为四个字节并正确对齐,以便它们可以被理解,与读取一个普通的旧 32 位整数相比,这是一个困惑的过程。
请记住,MySQL 来自一个高端服务器拥有 64 MB 内存和 9 GB 硬盘的时代。那时你确实需要削减字节,因为你只有少数字节。
现在我们还有其他顾虑,比如你会不会不小心耗尽你的 24 位整数空间,比如 Slashdot did由于您打算在此处进行的那种“优化”,他们的网站出现故障。
小心点。当您有具体理由时进行优化,而不仅仅是因为您认为需要这样做。避免过早优化是开发过程中的一个持续斗争,但如果您有纪律,就可以避免它。
关于mysql - 如果将 INT 列更改为 MEDIUMINT,我将节省多少大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50053088/
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章详解dedecms后台编辑器将回车 改为 的方法由作者收集整理,如果你对
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 6 年前。 Improve th
不是将代码放在正文的头部或末尾(我把它放在正文的末尾),如果我将代码放在 JS 文件中而不是在 html 中它自己的脚本标记,是否可以? (我假设它像任何其他代码一样工作正常,但我问以防万一) 最佳答
我尝试执行从\e 命令编写的查询,但现在我无法执行任何查询,但可以在 PSQL 中执行命令。 现在我注意到这一点,我输入的命令现在在\e 中。 当我关闭\e(尝试运行它)时问题开始了。 最佳答案 ps
我有一个这样的字符串($ 字符总是被其他字符包围): a$b c$d e$f 我希望我的字符串方法在 $ 前面放置一个 \ 并删除换行符: a\$bc\$de\$f 我试过了,但它没有放入 \ 字符:
我需要使用 Java 构建一个 XML 文件。问题是我必须使用一些特殊字符,例如“ć”,然后在我的移动应用程序中读取它。 如果我手动更改 ć 就可以正常工作至 ć在我的 XML 文件中的记事
我有一个removeUser 页面,我在其中使用,然后使用submitForm() 函数进行错误处理。这段代码运行得非常好: export default function RemoveUserPag
我在数据库 “2048-05-21” 中有一个看起来像这样的日期 我只想得到年份,在这一年我只想得到两个后面的数字并将两个前面的数字更改为19 example: data : 2048-05-21 1
public class Venus1 { public static void main(String args[]) { int[]x={1,2,3};
我有以下 PHP 脚本,现在我需要在 JavaScript 中做同样的事情。 JavaScript 中是否有类似于 PHP 函数的函数,我已经搜索了好几天但找不到类似的东西?我想做的是计算某个单词在数
这个问题在这里已经有了答案: Is it bad practice to specify an array size using a variable instead of `#define` in
我陷入了一种情况,我必须通过“选中”工具栏中的复选框来“选中”列表中存在的所有复选框。 这是创建复选框列表的代码:- itemTpl: 'checked="checked" /> {groupName
我正在使用Python3。在分析一些网站时,我遇到了一些奇怪的字符并寻找解决方案。我找到了一个,但在找到解决方案之前,我尝试了一些方法,并且知道我无法重置它。当我使用 Jupyter 笔记本将列表 l
我在 http 下有 unity android app 和 site api 的工作基础设施。 最近换了服务器,申请了ssl证书。现在我的 api 在 https 下。 在 unity 应用程序中,
我在 http 下有 unity android app 和 site api 的工作基础设施。 最近换了服务器,申请了ssl证书。现在我的 api 在 https 下。 在 unity 应用程序中,
我在 Objective-C 中有一些代码。我想,我收到了 NSString 类型,但是当我尝试将它保存在核心数据中时,我得到了一个 user.clientID = clientID; 错误,例如:
在表中我有一个名为 CallTime 的字段 (Varchar)。 包括晚上8:00、晚上8:40、上午10:00等时间 我想将字段类型更改为“时间”并更新时间格式。该怎么做? 谢谢 最佳答案 UPD
这个问题在这里已经有了答案: C# - for Loop Freezes at strange intervals (3 个答案) 关闭 6 年前。 我试图解决 problem #14 from P
我今天在 Pycharm 社区版 5.0.3 中收到了这个错误,想知道这是否只是我做错了/没有意识到,或者是 PyCharm lint 问题。重现错误的代码是 mylist = list() # fi
我的目标是将数据库中的随机文本显示到网页上。首先,我不知道为什么我的数据没有保存,为什么我得到的是[Entity of type sec.helloweb.HelloMessage with id:
我是一名优秀的程序员,十分优秀!