mysql中的数据类型
数值类型
严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),
关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。
create table t1 (id1 int,id2 int(5));
近似数值数据类型(FLOAT、REAL和DOUBLE PRECISION)。
create table t2 (id1 float(5,2),id2 double(5,2),id3 decimal(5,2));
都遵循四舍五入原则
create table t3 (id1 float,id2 double,id3 decimal);
decimal默认值为(10,0)的格式,不带小数位
float为单精度,double为双精度,小数部分位数过长时,数值会出现差异
日期和时间类型
表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
TIMESTAMP类型有专有的自动更新特性
类型 格式 描述
DATE YYYY-MM-DD 年月日
TIME HH:MM:SS 时分秒
YEAR YYYY 年份值
DATETIME YYYY-MM-DD HH:MM:SS 年月日时分秒
TIMESTAMP YYYYMMDD HHMMSS 混合日期和时间值,时间戳
date/time/datetime示例
mysql> create table t4 (d date,t time,dt datetime);
Query OK, 0 rows affected (0.02 sec)
mysql> desc t4;
+-------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| d | date | YES | | NULL | |
| t | time | YES | | NULL | |
| dt | datetime | YES | | NULL | |
+-------+----------+------+-----+---------+-------+
3 rows in set (0.01 sec)
mysql> insert into t4 values (now(),now(),now());
Query OK, 1 row affected, 1 warning (0.01 sec)
mysql> select * from t4;
+------------+----------+---------------------+
| d | t | dt |
+------------+----------+---------------------+
| 2018-09-21 | 14:51:51 | 2018-09-21 14:51:51 |
+------------+----------+---------------------+
1 row in set (0.00 sec)
mysql> insert into t4 values (null,null,null);
Query OK, 1 row affected (0.01 sec)
mysql> select * from t4;
+------------+----------+---------------------+
| d | t | dt |
+------------+----------+---------------------+
| 2018-09-21 | 14:51:51 | 2018-09-21 14:51:51 |
| NULL | NULL | NULL |
+------------+----------+---------------------+
2 rows in set (0.00 sec)
timestamp
create table t5 (id1 timestamp);
desc t5;
+-------+-----------+------+-----+-------------------+-----------------------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-----------+------+-----+-------------------+-----------------------------+
| id1 | timestamp | NO | | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
+-------+-----------+------+-----+-------------------+-----------------------------+
insert into t6 values (19700101080001);
mysql> select * from t6;
+---------------------+
| t1 |
+---------------------+
| 1970-01-01 08:00:01 |
+---------------------+
insert into t6 values (‘2038-01-19 11:14:07‘);
timestamp注意点:
1.插入数据,会自动插入当前时间的时间
2.添加新的一列,默认值是‘0000-00-00 00:00:00‘
3.手动修改新的列默认值为当前时间
alter table t5 modify id2 timestamp default current_timestamp;
4.timestamp时间的下限是19700101080001
5.timestamp时间的上限是2038-01-19 11:14:07
字符串类型
字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。
类型 | 大小 | 用途 |
---|---|---|
CHAR | 0-255字节 | 定长字符串 |
VARCHAR | 0-65535 字节 | 变长字符串 |
TINYBLOB | 0-255字节 | 不超过 255 个字符的二进制字符串 |
TINYTEXT | 0-255字节 | 短文本字符串 |
BLOB | 0-65 535字节 | 二进制形式的长文本数据 |
TEXT | 0-65 535字节 | 长文本数据 |
MEDIUMBLOB | 0-16 777 215字节 | 二进制形式的中等长度文本数据 |
MEDIUMTEXT | 0-16 777 215字节 | 中等长度文本数据 |
LONGBLOB | 0-4 294 967 295字节 | 二进制形式的极大文本数据 |
LONGTEXT | 0-4 294 967 295字节 | 极大文本数据 |
常用:char和varchar
CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。
CHAR列的长度固定为创建表是声明的长度,范围(0-255);而VARCHAR的值是可变长字符串范围(0-65535)。
mysql> create table t9 (v varchar(4),c char(4));
Query OK, 0 rows affected (0.01 sec)
mysql> insert into t9 values (‘ab ‘,‘ab ‘);
Query OK, 1 row affected (0.00 sec)
# 在检索的时候char数据类型会去掉空格
mysql> select * from t9;
+------+------+
| v | c |
+------+------+
| ab | ab |
+------+------+
1 row in set (0.00 sec)
# 来看看对查询结果计算的长度
mysql> select length(v),length(c) from t9;
+-----------+-----------+
| length(v) | length(c) |
+-----------+-----------+
| 4 | 2 |
+-----------+-----------+
1 row in set (0.00 sec)
# 给结果拼上一个加号会更清楚
mysql> select concat(v,‘+‘),concat(c,‘+‘) from t9;
+---------------+---------------+
| concat(v,‘+‘) | concat(c,‘+‘) |
+---------------+---------------+
| ab + | ab+ |
+---------------+---------------+
1 row in set (0.00 sec)
# 当存储的长度超出定义的长度,会截断
mysql> insert into t9 values (‘abcd ‘,‘abcd ‘);
Query OK, 1 row affected, 1 warning (0.01 sec)
mysql> select * from t9;
+------+------+
| v | c |
+------+------+
| ab | ab |
| abcd | abcd |
+------+------+
2 rows in set (0.00 sec)
单选enum和多选set
ENUM中文名称叫枚举类型,它的值范围需要在创建表时通过枚举方式显示。ENUM只允许从值集合中选取单个值,而不能一次取多个值。
SET和ENUM非常相似,也是一个字符串对象,里面可以包含0-64个成员。根据成员的不同,存储上也有所不同。set类型可以允许值集合中任意选择1或多个元素进行组合。
mysql> create table t10 (name char(20),gender enum(‘female‘,‘male‘));
Query OK, 0 rows affected (0.01 sec)
# 选择enum(‘female‘,‘male‘)中的一项作为gender的值,可以正常插入
mysql> insert into t10 values (‘nezha‘,‘male‘);
Query OK, 1 row affected (0.00 sec)
# 不能同时插入‘male,female‘两个值,也不能插入不属于‘male,female‘的值
mysql> insert into t10 values (‘nezha‘,‘male,female‘);
ERROR 1265 (01000): Data truncated for column ‘gender‘ at row 1
mysql> create table t11 (name char(20),hobby set(‘抽烟‘,‘喝酒‘,‘烫头‘,‘翻车‘));
Query OK, 0 rows affected (0.01 sec)
# 可以任意选择set(‘抽烟‘,‘喝酒‘,‘烫头‘,‘翻车‘)中的项,并自带去重功能
mysql> insert into t11 values (‘yuan‘,‘烫头,喝酒,烫头‘);
Query OK, 1 row affected (0.01 sec)
mysql> select * from t11;
+------+---------------+
| name | hobby |
+------+---------------+
| yuan | 喝酒,烫头 |
+------+---------------+
1 row in set (0.00 sec)
# 不能选择不属于set(‘抽烟‘,‘喝酒‘,‘烫头‘,‘翻车‘)中的项,
mysql> insert into t11 values (‘alex‘,‘烫头,翻车,看妹子‘);
ERROR 1265 (01000): Data truncated for column ‘hobby‘ at row 1