MySQL调优(一):数据类型优化

目录

三个原则

更小的通常更好

简单就好

尽量避免NULL

1、整数类型

2、实数类型

3、字符串类型

4、日期和时间类型


三个原则

更小的通常更好

更小的数据类型通常更快,因为它们占用更少的磁盘、内存和CPU缓存,并且处理时需要的CPU周期也更少。

简单就好

简单数据类型的操作通常需要更少的CPU周期。

尽量避免NULL

如果查询中包含可为NULL的列,对MySQL来说更难优化,因为可为NULL的列使得索引、索引统计和值比较都更复杂。可为NULL的列会使用更多的存储空间,在MySQL里也需要特殊处理。当可为NULL的列被索引时,每个索引记录需要一个额外的字节,在MyISAM里甚至还可能导致固定大小的索引(例如只有一个整数列的索引)变成可变大小的索引。

1、整数类型

数据类型位数(N)存储值范围(-2^{(N-1)} 到 2^{(N-1)}-1)
TINYINT8-128 ~ 127
SMALLINT16-32768 ~ 32767
MEDIUMINT24-8388608 ~ 8388607
INT32-2^{(32-1)} ~ 2^{(32-1)}-1
BIGINT64-2^{(64-1)} ~ 2^{(64-1)}-1

2、实数类型

数据类型含义
FLOAT(m,d)8位精度(4字节)
DOUBLE(m,d)16位精度(8字节)
DECIMAL(m,d)参数m<65 是总个数,d<30且 d<m 是小数位

因为需要额外的空间和计算开销,所以应该尽量只在对小数进行精确计算时才使用DECIMAL。但在数据量比较大的时候,可以考虑使用BIGINT代替DECIMAL,将需要存储的货币单位根据小数的位数乘以相应的倍数即可。这样可以同时避免浮点存储计算不精确和DECIMAL精确计算代价高的问题。

3、字符串类型

数据类型含义
CHAR固定长度,最多255个字符
VARCHAR

可变长度,最多65535个字节

TINYTEXT可变长度,最多255个字符
TEXT可变长度,最多65535个字符
MEDIUMTEXT可变长度,最多2的24次方-1个字符
LONGTEXT可变长度,最多2的32次方-1个字符

注意:

  • 当存储CHAR值时,MySQL会删除所有的末尾空格。
  • VARCHAR需要使用1或2个额外字节记录字符串的长度:如果列的最大长度小于或等于255字节,则只使用1个字节表示,否则使用2个字节表示。

4、日期和时间类型

数据类型含义
TIMESTAMP4字节,从1970年到2038年,精度为秒,与时区有关
DATETIME8字节,从1001年到9999年,精度为秒,与时区无关

除了特殊行为之外,通常也应该尽量使用TIMESTAMP,因为它比DATETIME空间效率更高。有时候人们会将Unix时间戳存储为整数值,但这不会带来任何收益。用整数保存时间戳的格式通常不方便处理,所以我们不推荐这样做。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL性能调优是指通过优化数据库的配置、索引设计、查询语句以及缓存利用等技术手段,提升MySQL数据库的性能。根据引用中提到的内容,可以从以下几个方面进行MySQL性能调优: 1. 索引优化:合理设计和使用索引可以大大提高查询速度。可以使用适当的索引类型、合理选择索引列和优化查询语句来提高索引的效率。 2. 查询优化:通过优化查询语句的写法、避免全表扫描、减少不必要的连接操作等方式,提升查询的效率。可以使用EXPLAIN命令分析查询语句的执行计划,找出慢查询的原因,并进行相应的优化。 3. 缓存利用:使用MySQL的查询缓存可以将查询结果缓存起来,减少重复查询的开销。此外,还可以使用Redis等内存数据库作为缓存,提高访问速度。 4. 数据库扩展:根据业务需求,可以采用垂直扩展和水平扩展两种方式来扩展数据库的性能。垂直扩展是通过提升服务器硬件性能来增加数据库的处理能力,如增加内存、CPU等资源。水平扩展是通过增加数据库实例或分片来分散负载,提高并发处理能力。 5. 高可用性和负载均衡:为了提高数据库的可用性和负载均衡能力,可以使用主从复制和读写分离等技术。主从复制可以将数据从主数据库同步到多个从数据库,提供数据冗余和故障恢复能力。读写分离可以将读操作分发到多个从数据库,减轻主数据库的负载压力。 通过以上的性能调优方法,可以提升MySQL数据库的响应速度、并发处理能力和可用性,从而提高应用系统的整体性能。<span class="em">1</span> #### 引用[.reference_title] - *1* [MySQL学习笔记5-数据库性能优化与扩展.md](https://download.csdn.net/download/weixin_52057528/88244498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值