查看磁盘空间占用,t3 占用最大,t1 占用最小 。所以说如果整数存储范围有固定上限,并且未来也没有必要扩容的话 , 建议选择最小的类型,当然了对其他类型也适用 。root@ytt-pc:/var/lib/mysql/3305/ytt# ls -sihl总用量 3.0G3541825 861M -rw-r----- 1 mysql mysql 860M 12月 10 11:36 t1.ibd3541820 989M -rw-r----- 1 mysql mysql 988M 12月 10 11:38 t2.ibd3541823 1.2G -rw-r----- 1 mysql mysql 1.2G 12月 10 11:39 t3.ibd
二、浮点数 / 定点数先说 浮点数,float 和 double 都代表浮点数,区别简单记就是 float 默认占 4 Byte 。float(p) 中的 p 代表整数位最小精度 。如果 p24 则直接转换为 double,占 8 Byte 。p 最大值为 53,但最大值存在计算不精确的问题 。再说 定点数,包括 decimal 以及同义词 numeric,定点数的整数位和小数位分别存储,有效精度最大不能超过 65 。所以区别于 float 的在于精确存储,必须需要精确存储或者精确计算的最好定义为 decimal 即可 。示例 3创建一张表 y1 , 分别给字段 f1,f2,f3 不同的类型 。mysql-(ytt/3305)-create table y1(f1 float,f2 double,f3 decimal(10,2));Query OK, 0 rows affected (0.03 sec)
三、字符类型字符类型和整形一样 , 用途也很广 。用来存储字符、字符串、MySQL 所有未知的类型 。可以简单说是万能类型!
char(10) 代表最大支持 10 个字符存储,varhar(10) 虽然和 char(10) 可存储的字符数一样多,不同的是 varchar 类型存储的是实际大小,char 存储的理论固定大小 。具体的字节数和字符集相关 。示例 4例如下面表 t4,两个字段 c1,c2 , 分别为 char 和 varchar 。mysql-(ytt/3305)-create table t4 (c1 char(20),c2 varchar(20));Query OK, 0 rows affected (0.02 sec)
所以在 char 和 varchar 选型上,要注意看是否合适的取值范围 。比如固定长度的值 , 肯定要选择 char;不确定的值,则选择 varchar 。
四、日期类型日期类型包含了 date,time,datetime,timestamp , 以及 year 。year 占 1 Byte,date 占 3 Byte 。
time,timestamp,datetime 在不包含小数位时分别占用 3 Byte,4 Byte,8 Byte;小数位部分另外计算磁盘占用 , 见下面表格 。
请点击输入图片描述
请点击输入图片描述
请点击输入图片描述
注意:timestamp 代表的时间戳是一个 int32 存储的整数,取值范围为 '1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999';datetime 取值范围为 '1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999' 。
综上所述,日期这块类型的选择遵循以下原则:
1. 如果时间有可能超过时间戳范围,优先选择 datetime 。2. 如果需要单独获取年份值 , 比如按照年来分区,按照年来检索等,最好在表中添加一个 year 类型来参与 。3. 如果需要单独获取日期或者时间,最好是单独存放,而不是简单的用 datetime 或者 timestamp 。后面检索时,再加函数过滤,以免后期增加 SQL 编写带来额外消耗 。
4. 如果有保存毫秒类似的需求 , 最好是用时间类型自己的特性,不要直接用字符类型来代替 。MySQL 内部的类型转换对资源额外的消耗也是需要考虑的 。
示例 5
建立表 t5,对这些可能需要的字段全部分离开,这样以后写 SQL 语句的时候就很容易了 。
当然了,这种情形占用额外的磁盘空间 。如果想在易用性与空间占用量大这两点来折中,可以用 MySQL 的虚拟列来实时计算 。比如假设 c5 字段不存在,想要得到 c5 的结果 。mysql-(ytt/3305)-alter table t5 drop c5, add c5 year generated always as (year(c1)) virtual;Query OK, 1 row affected (2.46 sec)Records: 1Duplicates: 0Warnings: 0
五、二进制类型
binary 和 varbinary 对应了 char 和 varchar 的二进制存储,相关的特性都一样 。不同的有以下几点:
推荐阅读
- 砍价技巧翡翠直播,直播现场砍价翡翠
- 怎么查看硬盘4k对齐,怎么查看电脑硬盘4k对齐
- 显卡怎么处理翻新问题,显卡怎么处理翻新问题视频
- linux命令关闭套接字 linux怎么关闭指定端口
- 剪辑视频音乐要什么格式,剪辑恐怖视频用什么音乐
- 飞利浦店面如何推广的,飞利浦推广方案
- 手机yy怎么直播王者,怎么用手机在yy直播王者荣耀
- 常用linux命令10个 十个常用linux命令
- css里属性英文,css的属性和属性值有哪些