数据库(MySQL)—— 数据类型

数据库(MySQL)------ 数据类型

我们今天来看MySQL中的数据类型:

MySQL中的数据类型

MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。

数值类型

类型 大小 有符号(SIGNED)范围 无符号(UNSIGNED)范围 描述
TINYINT 1 byte (-128, 127) (0, 255) 小整数值
SMALLINT 2 bytes (-32768, 32767) (0, 65535) 大整数值
MEDIUMINT 3 bytes (-8388608, 8388607) (0, 16777215) 大整数值
INT/INTEGER 4 bytes (-2147483648, 2147483647) (0, 4294967295) 大整数值
BIGINT 8 bytes (-2^63, 2^63-1) (0, 2^64-1) 极大整数值
FLOAT 4 bytes (-3.402823466 E+38, 3.402823466351 E+38) 0和(1.175494351 E-38, 3.402823466 E+38) 单精度浮点数值
DOUBLE 8 bytes (-1.7976931348623157 E+308, 1.7976931348623157 E+308) 0和(2.2250738585072014 E-308, 1.7976931348623157 E+308) 双精度浮点数值
DECIMAL 依赖于M(精度)和D(标度)的值 依赖于M(精度)和D(标度的值 小数值(精确定点数),M为精度,D为标度

这里简单介绍一下精度和标度:

小数的精度 (Precision)和标度(Scale)是描述数字数据存储和表示时两个重要的概念,尤其是在数据库和一些编程环境中。

  • 精度(Precision) 指的是一个数字中所有数字的总数,包括整数部分和小数部分的所有位数。换句话说,它是数字能够表示的总的位数,不区分小数点前后。例如,数字 123.456 的精度是 6(包括三位整数和三位小数)。
  • 标度(Scale) 特别指定了小数点后面数字的位数。它代表小数部分的有效位数。在上述例子中,123.456 的标度是 3,因为有三位小数。

我们可以根据上面的信息在创建表时选择适合的数据类型:

比如我们可以看看之前创建的staff表:
一个人的年龄不可能是小数,而且一个人最大的年龄也不过一百来岁,也不会为负数,所以我们使用 无符号的TINYINT是最合适的:

sql 复制代码
-- 修改 staff的age数据类型
ALTER TABLE staff MODIFY COLUMN age TINYINT UNSIGNED;

字符串类型

类型 大小 描述
CHAR 0-255 bytes 定长字符串(需要指定长度)
VARCHAR 0-65535 bytes 变长字符串(需要指定长度)
TINYBLOB 0-255 bytes 不超过255个字符的二进制数据
TINYTEXT 0-255 bytes 短文本字符串
BLOB 0-65 535 bytes 二进制形式的长文本数据
TEXT 0-65 535 bytes 长文本数据
MEDIUMBLOB 0-16 777 215 bytes 二进制形式的中等长度文本数据
MEDIUMTEXT 0-16 777 215 bytes 中等长度文本数据
LONGBLOB 0-4 294 967 295 bytes 二进制形式的极大文本数据
LONGTEXT 0-4 294 967 295 bytes 极大文本数据

字符串的数据类型分为两类,带BLOB和不带BLOB的,带BLOB是储存二进制的,但一般不常用。

我们再来看看char和varchar:

char 与 varchar 都可以描述字符串,char是定长字符串,指定长度多长,就占用多少个字符,和

字段值的长度无关 。而varchar是变长字符串,指定的长度为最大占用长度 。相对来说,char的性能会更高些。

sql 复制代码
如:
1). 用户名 username ------> 长度不定, 最长不会超过50
		username varchar(50)
2). 性别 gender ---------> 存储值, 不是男,就是女
		gender char(1)
3). 手机号 phone --------> 固定长度为11
		phone char(11)

时间戳类型

类型 大小 范围 格式 描述
DATE 3 1000-01-01 至 9999-12-31 YYYY-MM-DD 日期值
TIME 3 -838:59:59 至 838:59:59 HH:MM:SS 时间值或持续时间
YEAR 1 1901 至 2155 YYYY 年份值
DATETIME 8 1000-01-01 00:00:00 至 9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 混合日期和时间值
TIMESTAMP 4 1970-01-01 00:00:01 至 2038-01-19 03:14:07 YYYY-MM-DD HH:MM:SS 混合日期和时间值,时间戳
sql 复制代码
如:
1). 生日字段 birthday
		birthday date
2). 创建时间 createtime
		createtime datetime

一个实例

设计一张员工信息表,要求如下:

  1. 编号(纯数字)
  2. 员工工号 (字符串类型,长度不超过10位)
  3. 员工姓名(字符串类型,长度不超过10位)
  4. 性别(男/女,存储一个汉字)
  5. 年龄(正常人年龄,不可能存储负数)
  6. 身份证号(二代身份证号均为18位,身份证中有X这样的字符)
  7. 入职时间(取值年月日即可)
sql 复制代码
CREATE TABLE staff(
    -- 编号
    id INT  COMMENT '编号',
    work_id VARCHAR(10) COMMENT '员工工号',
    worker_name VARCHAR(10) COMMENT '员工姓名',
    worker_genger CHAR(1) COMMENT '姓名',
    age TINYINT UNSIGNED COMMENT '年龄',
    identity CHAR(18) COMMENT '身份证号',
    entry_date DATE COMMENT '入职时间'
) COMMENT '员工表';
相关推荐
小吴编程之路7 小时前
MySQL 索引核心特性深度解析:从底层原理到实操应用
数据库·mysql
~莫子7 小时前
MySQL集群技术
数据库·mysql
凤山老林7 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
就不掉头发7 小时前
Linux与数据库进阶
数据库
与衫7 小时前
Gudu SQL Omni 技术深度解析
数据库·sql
咖啡の猫8 小时前
Redis桌面客户端
数据库·redis·缓存
oradh8 小时前
Oracle 11g数据库软件和数据库静默安装
数据库·oracle
what丶k8 小时前
如何保证 Redis 与 MySQL 数据一致性?后端必备实践指南
数据库·redis·mysql
_半夏曲8 小时前
PostgreSQL 13、14、15 区别
数据库·postgresql
把你毕设抢过来8 小时前
基于Spring Boot的社区智慧养老监护管理平台(源码+文档)
数据库·spring boot·后端