Mysql 数据类型
1. 数值类型:
包含整数类型 TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT、浮点小数数据类型 FLOAT 和 DOUBLE,定点小数类型 DECIMAL。
| 类型 | 存储 | 范畴(有符号) | 无符号 |
| —————- | ——- | ———————- | ———— |
| TINYINT | 1 字节 | -128~127 | 0~255() |
| SMALLINT | 2 字节 | 32768~32767 | 0~65535 |
| MEDIUMINT | 3 字节 | -8388608~8388607 | 0~16777215 |
| INT | 4 字节 | -2147483648~2147483647 | 0~4294967295 |
| BIGINT | 8 字节 | | |
| | | | |
| FLOAT | 4 字节 | | |
| DOUBLE | 8 字节 | | |
| DECIMAL(M,N) | M+ 2 字节 | | |
<span style=”color:red”> 留神:</span>
CREATE TABLE test1(id INT(3),
`name` VARCHAR(5),
age INT(3)
);
id INT(3)
括号内的 3 不是限度存储数据的大小, 而是批示显示宽度. 显示宽度和数据类型的取值范畴是无关的
显示宽度只用于显示,并不能限度取值范畴和占用空间。例如:INT(3)会占用 4 字节的存储空间,并且容许的最大值不会是 999,而是 INT 整型所容许的最大值。显示宽度只是指明 MySQL 最大可能显示的数字个数,数值的位数小于指定的宽度时会由空格填充
例如: 向 test1
入id = 999999
的数据还是会胜利.
INSERT INTO test1 VALUES(999999,'小明',12);
select * from test1 where id = 999999;
id name age
999999 小明 12
<span style=”color:red”>DECIMAL</span>。浮点数类型和定点数类型都能够用(M,N)来示意。其中,M 称为精度,示意总共的位数;N 称为标度,示意小数的位数.DECIMAL 若不指定精度则默认为(10,0)
不论是定点数还是浮点数类型,如果用户指定的精度超出精度范畴,则会四舍五入
CREATE TABLE test2(id INT(4),
score DECIMAL(3,2)
);
INSERT INTO test2 VALUES(1,5.123),(2, 5.236),(3,5.1);
SELECT * FROM test2;
-- 后果
id score
1 5.12
2 5.24
3 5.10
如果插入大于 999.99
的数就会报错了
insert into test2 values(4, 1000.4567);
-- 后果
查问:insert into test2 values(4, 1000.4567)
错误代码:1264
Out of range value for column 'score' at row 1
2. 日期 / 工夫类型:
包含 YEAR、TIME、DATE、DATETIME 和 TIMESTAMP
| 类型 | 日期格局 | 范畴 | |
| ——— | ——————- | ——— | —– |
| YEAR | YYYY | 1901-2155 | 1 字节 |
| TIME | HH:MM:SS | | 3 字节 |
| DATE | YYYY-MM-DD | | 3 字节 |
| DATETIME | YYYY-MM-DD HH:MM:SS | | 8 字节 |
| TIMESTAMP | YYYY-MM-DD HH:MM:SS | | 4 字节 |
<span style=”color:red”> 留神:</span> TIMESTAMP 的范畴是 1970 年到 2038 年
TIMESTAMP 与 DATETIME 除了存储字节和反对的范畴不同外,还有一个最大的区别就是:DATETIME 在存储日期数据时,按理论输出的格局存储,即输出什么就存储什么,与时区无关;而 TIMESTAMP 值的存储是以 UTC(世界规范工夫)格局保留的,存储时对以后时区进行转换,检索时再转换回以后时区。查问时,不同时区显示的工夫值是不同的。
DATE:
(1)以‘YYYY-MM-DD’或者‘YYYYMMDD’字符串格局示意的日期,取值范畴为‘1000-01-01’~‘9999-12-3’。例如,输出‘2012-12-31’或者‘20121231’,插入数据库的日期都为 2012-12-31。
(2)以‘YY-MM-DD’或者‘YYMMDD’字符串格局示意的日期,在这里 YY 示意两位的年值。蕴含两位年值的日期会令人含糊,因为不晓得世纪。MySQL 应用以下规定解释两位年值:‘00~69’范畴的年值转换为‘2000~2069’;‘70~99’范畴的年值转换为‘1970~1999’。例如,输出‘12-12-31’,插入数据库的日期为 2012-12-31;输出‘981231’,插入数据的日期为 1998-12-31。
(3)以 YY-MM-DD 或者 YYMMDD 数字格局示意的日期,与后面类似,00~69 范畴的年值转换为 2000~2069,70~99 范畴的年值转换为 1970~1999。例如,输出 12-12-31 插入数据库的日期为 2012-12-31;输出 981231,插入数据的日期为 1998-12-31
3. 字符串类型:
包含 CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM 和 SET 等。字符串类型又分为文本字符串和二进制字符串
| 类型 | 存储 | 大小 | |
| ———- | —————— | ————————— | —- |
| CHAR(M) | M 字节,1 <= M <=255 | | |
| VARCHAR | L+ 1 字节, L<= M , | | |
| TINYTEXT | | 0-255 字节 | |
| TEXT | | 0-65535 字节 | |
| MEDIUMTEXT | | 0-16,777,215 字节 | |
| LONGTEXT | | 0-4,294,967,295 or 4GB 字节 | |
| ENUM | | 1 或 2 字节 | |
| | | | |
| TINYBLOB | | 0-255 字节 | |
| BLOB | | 0-65535 字节 | |
| MEDIUMBLOB | | 0-16,777,215 字节 | |
| LONGBLOB | | 0-4,294,967,295 or 4GB 字节 | |
varchar(M)
阐明 括号内的 M 和 INT(4)
类型的限度不一样, 这里 M 对插入数据的长度有限度, 超长就会报错
CREATE TABLE test3(id INT(4),
`name` VARCHAR(5),
`remark` varchar(1000)
);
insert into test3 values(1, '小红','第一条数据');
-- 数据失常插入
id name remark
1 小红 第一条数据
数据超长状况
insert into test3 values(1, '这个名字真长','第二条数据');
-- 显示 name 字段超长
<e> 查问:insert into test3 values(1, '这个名字真长','第二条数据')
错误代码:1406
Data too long for column 'name' at row 1
INSERT INTO test3 VALUES(1, 'abcdef','第三条数据');
-- 显示还是超长
查问:INSERT INTO test3 VALUES(1, 'abcdef','第三条数据')
错误代码:1406
Data too long for column 'name' at row 1
varchar 字段长度间接按字符计算不辨别中英文字符
本文由博客一文多发平台 OpenWrite 公布!