网站首页 > 博客文章 正文
在MySQL中数据类型有以下五种:
数字
整数:
常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyint unsigned,用来表示年龄(值范围是0-255)。
小数:
注意float(m,n)表示法中的m表示数字总共有m位,n表示小数有n位,那么整数部分只能有m-n位。
float默认保留5位小数、double默认保留16位小数、decimal默认是10位数字不含小数(它的最大范围是65位数字,其中小数可以保留30位)。
时间
表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
时间类型可以增加限定属性:
not null 非空
default current_timestamp 默认时间为当前时间
on update current_timestamp 更新数据时自动更新当前时间
date:用来记录各种日期,如出生日期、入职日期等关注日期而不关注时间的等信息。
time:用来记录时间安排(课程表、日程表)的信息、时长的等信息。
datetime:用户登录时间等
字符串
以上类型中char和varchar类型用得最多。
char类型为定长字符型,长度固定为声明的长度,范围是0-255字符数(注意不是字节数!使用utf8编码中文会占3个字节,也就是说255个中文字符实际上会占用765字节)。存储时数据长度不够声明的长度时末尾会被填充空格,取值时会舍弃末尾的空格部分,数据超过声明长度的部分会被舍弃。适合使用char类型的如身份证号、手机号、qq号、用户名、密码、银行卡号等。
varchar类型为不定长字符型,长度不固定但最长不能超过声明的长度,范围是0-65535字符数。存储时数据长度不够声明的长度时不会填充空格,数据最后会附加2个字节的长度信息,数据超过声明长度的部分会被舍弃。适合使用varchar类型的如评论、朋友圈、微博等。
char类型优点是检索速度快,缺点是浪费存储空间;varchar类型优点是节省存储空间,缺点是检索速度慢。
由于现在存储空间不再是瓶颈,所以在强调检索速度的场景优先使用char,只有在不确定字符串长度又不强调检索速度的场景才使用varchar。
enum单选
案例:
在下面的sql语句中创建了test表,它的gender字段约束了数据只能是’male’或’female’。
create table test(id int,name char(18),gender enum('male','female'));
如果该字段输其它内容会报错并导致整条数据不能存入数据库。如下面这条语句就会报错且数据不会保存到数据库。
insert into test values(1,'mike','不详');
只有输入正确的选项数据才能存入数据库。
insert into test values(1,'mike','male');
set多选
案例:
在下面的sql语句中创建了test表,它的hobby字段约束了数据只能从列表中选择’。
create table test(id int,name char(18),hobby set('抽烟','喝酒','烫头','洗脚'));
如果该字段输其它内容会报错并导致整条数据不能存入数据库。如下面这条语句就会报错且数据不会保存到数据库。
insert into test values (1,'mike','烫头,喝酒,抽烟,按摩’);
只有输入正确的选项数据才能存入数据库。
insert into test values (1,'mike','烫头,喝酒,抽烟');
注意上述多选中整个选项作为一个字符串且选项之间用英文逗号隔开。
- 上一篇: 数据丢失?别慌!MySQL备份恢复攻略
- 下一篇: MYSQL表设计规范(mysql设计表注意事项)
猜你喜欢
- 2025-06-23 MySQL合集-mysql5.7及mysql8的一些特性
- 2025-06-23 MySQL CREATE TABLE 简单设计模板交流
- 2025-06-23 MYSQL表设计规范(mysql设计表注意事项)
- 2025-06-23 数据丢失?别慌!MySQL备份恢复攻略
- 2025-06-23 MySQL设计规范(mysql 设计)
- 2025-06-23 MySQL数据实时增量同步到Elasticsearch
- 2025-06-23 MySQL 避坑指南之隐式数据类型转换
- 2025-06-23 MySQL数据库中,数据量越来越大,有什么具体的优化方案么?
- 2025-06-23 MySQL使用规范(mysql使用入门)
- 2025-06-23 第39期:MySQL 时间类分区写 SQL 注意事项
你 发表评论:
欢迎- 06-23MySQL合集-mysql5.7及mysql8的一些特性
- 06-23MySQL CREATE TABLE 简单设计模板交流
- 06-23MYSQL表设计规范(mysql设计表注意事项)
- 06-23MySQL数据库入门(四)数据类型简介
- 06-23数据丢失?别慌!MySQL备份恢复攻略
- 06-23MySQL设计规范(mysql 设计)
- 06-23MySQL数据实时增量同步到Elasticsearch
- 06-23MySQL 避坑指南之隐式数据类型转换
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)