Mysql字段类型

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字节

<b style="color:red">注意:</b>

CREATE TABLE test1(
   id INT(3),
   `name` VARCHAR(5),
   age INT(3)
);

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

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   

如果插入大于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字节

注意: 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字段长度直接按字符计算不区分中英文字符

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容

  • 字段类型数值MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数。许多不同的子类型对...
    小慕先森阅读 932评论 0 1
  • 前言: 要了解一个数据库,我们必须了解其支持的数据类型。MySQL 支持大量的字段类型,其中常用的也有很多。前面文...
    K_un阅读 239评论 0 1
  • TINYINT 1 字节SMALLINT 2 个字节MEDIUMINT 3 个字节INT 4 个字节INTEGER...
    素年锦时2021阅读 502评论 0 0
  • 1. bytes bytes = 8 bit 一个字节最多可以代表的数据长度是2的8次方 11111111 在计算...
    CookieziSui阅读 899评论 0 2
  • 最近需要对表加一个字段,同时觉得前期建立表的时候有点粗暴,没有加很对限制,比如有些字符串长度是有限制的,在创建表时...
    何甜甜在吗阅读 1,219评论 0 0