WHCSRL 技术网

Mysql字段类型

Mysql数据类型

1. 数值类型:

包括整数类型TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT、浮点小数数据类型FLOAT和DOUBLE,定点小数类型DECIMAL。

类型存储范围(有符号)无符号
TINYINT1字节-128~1270~255()
SMALLINT2字节32768~327670~65535
MEDIUMINT3字节-8388608~83886070~16777215
INT4字节-2147483648~21474836470~4294967295
BIGINT8字节
FLOAT4字节
DOUBLE8字节
DECIMAL(M,N)M+2字节

注意:

   CREATE TABLE test1(
      id INT(3),
      `name` VARCHAR(5),
      age INT(3)
   );
  • 1
  • 2
  • 3
  • 4

id INT(3)括号内的3不是限制存储数据的大小,而是指示显示宽度.显示宽度和数据类型的取值范围是无关的

显示宽度只用于显示,并不能限制取值范围和占用空间。例如:INT(3)会占用4字节的存储空间,并且允许的最大值不会是999,而是INT整型所允许的最大值。显示宽度只是指明MySQL最大可能显示的数字个数,数值的位数小于指定的宽度时会由空格填充

例如:向test1id = 999999的数据还是会成功.

   INSERT INTO test1 VALUES(999999,'小明',12);

   select * from test1 where id = 999999;

   id        name    age
   999999    小明    12
  • 1
  • 2
  • 3
  • 4
  • 5

DECIMAL。浮点数类型和定点数类型都可以用(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   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

如果插入大于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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

2. 日期/时间类型:

包括YEAR、TIME、DATE、DATETIME和TIMESTAMP

类型日期格式范围
YEARYYYY1901-21551字节
TIMEHH:MM:SS3字节
DATEYYYY-MM-DD3字节
DATETIMEYYYY-MM-DD HH:MM:SS8字节
TIMESTAMPYYYY-MM-DD HH:MM:SS4字节

注意: 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
VARCHARL+1字节, L<= M ,
TINYTEXT0-255 字节
TEXT0-65535 字节
MEDIUMTEXT0-16,777,215 字节
LONGTEXT0-4,294,967,295 or 4GB 字节
ENUM1或2字节
TINYBLOB0-255 字节
BLOB0-65535 字节
MEDIUMBLOB0-16,777,215 字节
LONGBLOB0-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   小红  第一条数据  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

数据超长情况

   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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

varchar字段长度直接按字符计算不区分中英文字符

本文由博客一文多发平台 OpenWrite 发布!

推荐阅读