首页 > 数据库 >MySql 数据类型选择与优化

MySql 数据类型选择与优化

时间:2024-06-01 20:01:41浏览次数:19  
标签:存储 TEXT Mysql 数据类型 MySql 类型 优化 CPU

选择优化的数据类型

更小的通常更好
一般情况下尽量使用可以正确存储数据的最小类型。更小的数据类型通常更快,因为它们占用更少的磁盘,内存和CPU缓存,并且处理时需要的CPU周期也更少。但也要确保没有低估需要存储值的范围。
简单就好
简单的数据类型通常需要更少的CPU周期。例如:整型比字符操作代价更低,因为字符集和校对规则(排序规则)使字符比较比整型比较更复杂。例如:应该使用 mysql 的内建类型而不是字符来存储日期和时间,另外一个应该使用整型存储IP地址。
尽量避免 NULL
NULL 使得索引、索引统计和值比较都更复杂

实数类型
DECIMAL 类型用于存储精确的小数。因为CPU 不支持对 DECIMAL 的直接计算,所以在 Mysql 5.0 和更高版本中,Mysql 服务器自身实现了 Decimal 的高精度计算。相对而言,CPU 直接支持原生浮点计算,所以浮点运算明显更快。Decimal 只是一种存储格式,在计算中 Decimal 会转换为 Double 类型。有时候也可以使用 Bigint 替代浮点型。

字符串类型
Varchar
Varchar 节省了存储空间,所以对性能也有帮助。但是,由于是变长的,在 Update 时可能使行长变得比原来更长,这就导致需要做额外的工作,比如导致频繁的页分裂和合并,从而产生大量磁盘碎片。
Char
Char 类型是定长的,当存储 Char 时, Mysql 会删除所有的末尾空格。对于经常变更的数据也不容易产生磁盘碎片。

[!NOTE] 慷慨是不明智的
更长的列会消耗更多的内存,因为 Mysql 通常会分配固定大小的内存块来保存内部值。尤其是使用内存临时表进行排序或操作时会特别糟糕。在使用磁盘临时表进行排序时也同样糟糕。
所以最好的策略是只分配真正需要的空间

BLOB 和 TEXT
Mysql 对 BLOB 和 TEXT 列进行排序与其它类型是不同的:它只对每个列的最前 max_sort_length 字节而不是整个字符串做排序。Memory 引擎不支持 BLOB 和 TEXT 类型,因此在包含 BLOB 和 TEXT 类型的列都会转而使用 MyIsam 磁盘临时表。

日期和时间类型
TIMESTAMP
TIMESTAMP 显示的值也依赖于时区
DATETIME
它把日期和时间封装到格式为 YYYYMMDDHHMMSS 的整数中,与时区无关。

[!NOTE] TIPS
有时候人们会将 UNIX时间戳存储为整数,但这将不会带来任何收益。用整数保存时间戳的格式通常不方便处理,所以我们不推荐这样做。

选择标识符
当选择标识列的类型时,不仅仅需要考虑存储类型,还需要考虑 Mysql 对这种类型怎么计算和比较。一旦选定了一种类型,要确保在所有关联表中都使用同样的类型。类型之间需要精确匹配,包括像 UNSIGNED 这样的属性。混用不同数据类型可能导致性能问题,即使没有性能影响,在比较操作时隐式类型转换也可能导致很难发现的错误。

选择合适的主键
大多数情况使用自增主键ID就可以解决问题,但当我们预估系统会有比较大的业务增长时,可以考虑使用分布式ID作为业务主键,避免后面分库分表时带来的不便

MySQL schema 设计中的陷阱

太多的列
MySQL 的存储引擎API工作时需要在服务器层和存储引擎层之间通过行缓冲格式拷贝数据,然后在服务器层将缓冲内容解码成各个列。从行缓冲格式将编码过的列转换成行数据结构的操作代价是非常高的。这个过程是CPU密集型的(太多的列会导致CPU占用过高)。
太多的关联
尽量不关联或者少关联表

标签:存储,TEXT,Mysql,数据类型,MySql,类型,优化,CPU
From: https://blog.csdn.net/u013911096/article/details/139378772

相关文章

  • Ansible05-Ansible进阶(流程控制、Roles角色、加密优化调优等)
    目录写在前面7Ansible进阶7.1流程控制7.1.1handlers触发器与notify7.1.1.1未使用handlers7.1.1.2使用handlers7.1.2when判断7.1.2.1when的语法7.1.2.2when判断主机名选择模块输出7.1.2.3when结合register变量7.1.3loop/with_items循环7.1.3.1with_items案......
  • MySQL基础操作
    1)cmd进入mysql控制台:mysql-uroot-p1234root为用户名,1234为密码或mysql-uroot-p1234或把密码换一行输入:mysql-uroot-p或mysql-uroot-p然后提示输入密码2)退出数据库控制台exit和quit3)查看所有数据库;showdatabases;4)显示时间selectnow(......
  • mysql 表被锁住
    在MySQL中,如果你发现一个表被锁住了,想要查询是哪个进程占用了这个锁,可以按照以下步骤操作: 1.**使用SHOWPROCESSLIST命令**:  首先,你可以使用`SHOWPROCESSLIST;`命令来查看当前所有活跃的连接和它们的状态。这将展示一个列表,包含每个线程的ID、用户、主机、数据库、执......
  • CSAPP 第五章 优化程序性能
    5-1&2优化程序性能保守性编译器优化是保守的,只要有矛盾就不会激进的优化。CPECPE表示每个元素执行所需要的周期数。如368+6*k,6就是CPE。一个优化的例子这个代码每一次迭代要读两次内存,写入一次。这个只用读一次。以上优化会有一定的效果,读写内存是占用时间的。5-3......
  • 第2章 变量和简单数据类型
            在本章中,你将学习可在Python程序中使用的各种数据,还将学习如何将数据存储到变量中,以及如何在程序中使用这些变量。2.1运行hello_world.py时发生的情况        运行hello_world.py时,Python都做了些什么呢?下面来深入研究一下。实际上,即便是运行简单......
  • MySQL常用语句总结
    本篇MySQL语句笔记录笔记所引用案例为B站未明学院SQL课程教学案例,个人觉得这个UP主的视频讲解特别仔细,感兴趣小伙伴可以去听听~一、数据库操作(MySQL运行界面)按Pageup和Pagedown可以将之前出现过的命令正序或者倒序展示,避免重复输入命令。--展示所有的数据库SHOWDATABASE......
  • 改进rust代码的35种具体方法-类型(二十)-避免过度优化的诱惑
    上一篇文章-改进rust代码的35种具体方法-类型(十九)-避免使用反射“仅仅因为Rust允许您安全地编写超酷的非分配零复制算法,并不意味着您编写的每个算法都应该是超级酷的、零复制和非分配的。”-trentj   这本书中的大多数项目都旨在帮助现有程序员熟悉Rust及其成语。......
  • 【问题解决】MySQL恢复数据库报错Unknown command '\''.
    问题使用以下命令备份恢复数据库,恢复失败提示ERRORatline39595:Unknowncommand'\''.#备份数据库mysqldump-uusername-p--no-create-db-Rdatabasename>dump.sql#恢复数据库mysql-uusername-pdatabasename2<dump.sql问题原因及解法原因:中文字符的问题......
  • builder导致的mp、mysql对应内容出错
    本来今天高高兴兴,BUG毁了这一天1、报错内容org.springframework.dao.DataIntegrityViolationException:Errorattemptingtogetcolumn'name'fromresultset.Cause:java.sql.SQLDataException:Cannotdeterminevaluetypefromstring'a';Cannotdetermine......
  • mysql数据库8.4免安装方法配置
    在执行以下操作时,先把以前的data删除,移除相关服务后再进行操作。netstopmysqlmysqld--remove【简单安装,且操作不复杂】#1、根目录下新建my.ini[mysqld]basedir=C:/mysqldatadir=C:/mysql/dataport=3306#2、空密码初始化mysqld--initialize-insecure--user=mysql--conso......