首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

详解 mysql int 类型长度值问题

秉着好奇心, 打开了 google ~ 引入大神解答. mysql 在建表时候 int 类型长度代表什么? 是该列允许存储值最大宽度吗?...所以我在网上查阅了一些资料, 也仔细看了 mysql 手册关于 int data type 说法. 以下是每个整数类型存储和范围 (来自 mysql 手册) ?...每个整数类型存储和范围.png 表格一共有四列分别表式: 字段类型, 占用字节数, 允许存储最小值, 允许存储最大值....mysql 我们看到现在我 number 字段, 长度 (M)=5, 属性 =UNSIGNED ZEROFILL(无符号, 用 0 来填充位数), 设置这个属性后我往表时插入数据, 系统会自动把 number...mysql 手册上还有这么一句话 "当 mysql 为某些复杂联结 (join) 生成临时表时,你可能会遇到问题,因为在这种情况下,mysql 信任地认为所有的值均适合原始列宽度".

3.5K20
您找到你想要的搜索结果了吗?
是的
没有找到

mysqlint长度意义

提问: mysql字段,unsigned int(3), 和unsinged int(6), 能存储数值范围是否相同。如果不同,分别是多大?...如果你答案和上面的一致,恭喜你和我犯了一样错误。...查下手册,解释是这样MySQL还支持选择在该类型关键字后面的括号内指定整数值显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定列宽度值时从左侧填满宽度。...显示宽度并不限制可以在列内保存范围,也不限制超过列指定宽度显示。...也就是说,int长度并不影响数据存储精度,长度只和显示有关,为了让大家看更清楚,我们在上面例子建表语句中,使用了zerofill。

3.9K10

MySQL索引长度限制

参考: http://dinglin.iteye.com/blog/1681332 单列索引长度限制     (5.6里面默认不能超过767bytes,5.7不超过3072bytes):     起因是...255×4>767, 于是增加了一个参数叫做 innodb_large_prefix     # 256由来: 只是因为char最大是255,所以以前程序员以为一个长度为255index就够用了,...--- by 阿里-丁奇 在MySQL5.6里默认 innodb_large_prefix=0 限制单列索引长度不能超过767bytes    官网文档:https://dev.mysql.com/doc...在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes 联合索引长度限制 (不能超过3072bytes...idx_a长度为:255*3*5= 3825 bytes ,大于最大值 3072 bytes  为什么3072,原因如下:    我们知道InnoDB一个page默认大小是16k。

5.3K30

一文搞懂MySQL表字段类型长度含义

不知道大家第一眼看标题时候有没有理解,什么是“字段类型长度”,这里我来解释下,就比如我们在MySQL建表时候,比如下面这个建表语句:CREATE TABLE `user` ( `id` int(10...,而每个类型+数字就是该字段类型长度,比如int(10)就是该字段是int类型长度为10,这下大家应该能理解什么是MySQL表字段类型长度了吧(其实在后续讲解中会发现这个并不是长度,而是宽度)那么重点问题来了...JSON 数据类型MySQL 从5.7.8 版本开始提供 JSON 数据类型支持,与之前将 JSON 数据以字符串形式存储在列相比,JSON 数据类型增加了以下支持:(1)它提供了 JSON 文档自动验证...(3)提供了相关操作JSON类型数据函数1.3 数据类型说明MySQL数据类型长度是固定,而不是由建表时指定,unsigned表示无符号类型CREATE TABLE `table01` ( `...;对某些值宽度短于该列宽度值进行左填补显示,而不是为了限制在该列存储值宽度,也不是为了限制那些超过该列指定宽度可被显示数字位数,因此我们得出一下结论:对于数值类型,可以不指定宽度,使用默认长度即可

1K11

Mysql类型

Mysql类型: 数字类型 字符串类型 布尔型 日期时间类型 数字类型: 1个字节=8比特,但数字里有一个比特用于符号占位 TINYINT 占用1个字节,表示范围:-128~127 SMALLINT...: \0表示一个字符串结束 CHAR(M) 固定长度字符串,长度最大为225个字符 VARCHAR(M) 长度可变字符串,长度最大为65535个字符 TEXT(M) 长度可变字符串,长度最大到4G...列上值往往是有限制,如: 性别:只能取男或女 政治面貌:只能取党员、团员、群众 高考成绩:FLOADT(4,1) 取值有规则 电话、手机号码:有格式要求 用户名:必须唯一 登录密码:密码不能为空字符串且长度不能少于...N位 员工所在部门:可取值必须在部门表存在过 主键约束: 列名 类型 PRIMARY KEY 声明为“主键”列上不能出现NULL值,且不能重复,如学生编号、商品编号。...非空约束: 列名 类型 NOT NULL 声明为“非空”约束列上不能出现NULL,但可以重复 检查约束对于Mysql不支持 默认值约束 列名 类型 Default 值 声明为“默认值”约束列上没有值将会默认采用默认设置

6.4K20

MysqlMySQL TIMESTAMP类型 和 DATETIME类型 区别

1、两者存储方式不一样 TIMESTAMP:把客户端插入时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。...DATETIME:不做任何改变,基本上是原样输入和输出 2、两者所能存储时间范围不一样 timestamp存储时间范围为:‘1970-01-01 00:00:01.000000’ 到 ‘2038-01...:00:00分保存数据,在东9区看到是09:00:00,datetime与时区无关 6、timestamp 4个字节存储(实际上就是int),datetime 8个字节 7、如果timestamp值超出范围...,mysql不会报错 8、如果是自动更新模式,手动修改数据导致timestamp字段更新 9、同时有两个timestamp字段默认值为current_timestamp会报错 参考资料: MySQL...TIMESTAMP类型 和 DATETIME类型 区别 http://www.studyofnet.com/news/1123.html

2.6K20

MySQL字节、编码、长度、值关系 原

都能存入n个字符,仅是实际字节长度有所区别 2.MySQL指定整数值显示宽度(例如,INT(4))。...该可选显示宽度规定用于显示宽度小于指定列宽度值时从左侧填满宽度。显示宽度并不限制可以在列内保存范围,也不限制超过列指定宽度显示。 ...建立这个长度是为了告诉MYSQL数据库我们这个字段存储数据宽度为5位数,  当然如果你不是5位数(只要在该类型存储范围之内)MYSQL也能正常存储 在Java中一共有八种基本数据类型。...根据int类型允许存储字节数是4个字节, 我们就能换算出int UNSIGNED(无符号)类型能存储最小值为0, 最大值为4294967295(即4B=32b, 最大值即为32个1组成); 浮点型...float和double是表示浮点型数据类型,他们之间区别在于他们精确度不同 float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以1038次方,同样,e-45

2.3K30

MySQL修改字段类型、字段名字、字段长度、字段小数点长度

文章目录 1:修改类型 2:修改长度 3: 同时修改列名和列数据类型 4:修改字段类型text(类型) ~>mediumtext(类型) 5:修改字段长度和字段小数点长度 6: 修改字段列名和字段类型...7:指定字段之后新增字段 8:更新表content_text字段类型 9:修改字段类型,修改长度和小数点位数 1:修改类型 mysql> alter table 表名 modify column 字段名...mysql 修改字段类型:alter table news modify column title text;我发现使用这句sql也可以直接修改字段原本类型!...通常可以写成 alter table 表名 modify column 列名 新类型例如:student表列sname类型是char(20),现在要修改为varchar(20),SQL语句如下...3: 同时修改列名和列数据类型 同时修改列名和列数据类型方法:通常可以写成 alter table 表名 change column 旧列名 新列名 新类型student表列sname类型

8.5K20

MySQL 日期时间类型

日期时间类型包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体取值范围,超出或非法其他值时,MySQL 会回退到 0。...TIMESTAMP 类型是个例外,给它设置一个超出范围值时,将保存上该类型允许最大值。...通过设置 MySQL 相关参数,日期类型可保存原本非法值,比如开启 ALLOW_INVALID_DATES 设置项时,可设置日期类型保存一个 2009-11-31 值,但正常情况下我们知道 11 月哪来什么...所以 MySQL 是支持将月日设置成 0,比如 2019-00-00。但这种情况下就无法从日期相关操作获得到准确结果,比如使用 DATE_SUB() 或 DATE_ADD() 函数时。...比如给一个日期格式列设置 10:11:12,虽然这个值看起来像时间类型,但还是可以正确在被解析成目标列格式,即日期。

6.7K20

MySQL数据类型

MySQL定义数据字段类型对数据库优化是非常重要,它支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。 数值类型 ? 日期和时间类型 ? 字符串类型 ?...CHAR 和 VARCHAR 类型类似,但它们保存和检索方式不同,它们最大长度和是否尾部空格被保留等方面也不同,在存储或检索过程不进行大小写转换。...另外,CHAR(n) 和 VARCHAR(n) 括号 n 代表字符个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。...BLOB 是一个二进制大对象,可以容纳可变数量数据,上表所示中有共有4种类型,它们区别在于可容纳存储范围不同。...TEXT 用于存文本数据,对应BLOB4种类型,4种类型存储最大长度不同,可根据实际情况选择。

2.8K20

MySQL数字类型、数值类型、时间类型

Float 4 bytes,Double 8 bytes Double [(M,D)] -1.79E+308~1.79E+308( 约 ) Decimal [(M,D)] 2.1 int(2)...2是能存储最小显示长度,如果插入数据不够2位时,需要在数据前面用0补满2位。比如定义一个age字段,其数据类型为int(4),那用select查询出来结果是“0002”。...但是我们发现,在实际查出来结果,并没有补全效果,这是因为系统默认不显示,如果想显示出来,增加zerofill约束即可。...最大长度为4294967295,如果输入值比最大长度更大,则数据库会自动转为这个最大数进行存储。这个数是232次方-1。int占32位。 2.3 int(2)和int(4)区别?...其最小显示长度分别为2和4。但是,这两个在硬盘中所占存储空间是一样。 2.4 int(2)和tinyint(2)区别?

3K20

MySQL数据类型_js数据类型

MySQL数据类型精讲 1.MySQL数据类型 常见数据类型属性,如下: 2.整数类型 2.1 类型介绍 整数类型一共有 5 种,包括 TINYINT、SMALLINT、MEDIUMINT、INT...如果保存时,数据实际长度比CHAR类型声明长度小,则会在 右侧填充 空格以达到指定长度。当MySQL检索CHAR类型数据时,CHAR类型字段会去除尾部空格。...每种TEXT类型保存数据长度和所占用存储空间不同,如下: 由于实际存储长度不确定, MySQL 不允许 TEXT 类型字段做主键。...MySQLBLOB类型包括TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB 4种类型,它们可容纳值最大长度不同。可以存储一个二进制大对象,比如 图片 、 音频 和 视频 等。...在MySQL 8.x版本,JSON类型提供了可以进行自动验证JSON文档和优化存储结构,使得在MySQL存储和读取JSON类型数据更加方便和高效。

6.7K20
领券