int(11)最大长度是多少,MySQL中varchar最大长度是多少?

int(11)最大长度是多少?

在SQL语句中int代表你要创建字段的类型,int代表整型,11代表字段的长度。

这个11代表显示宽度,整数列的显示宽度与mysql需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,比如,不管设定了显示宽度是多少个字符,bigint都要占用8个字节。

int是整型,(11)是指显示字符的长度,但要加参数的,最大为255,比如它是记录行数的id,插入10笔资料,它就显示00000000001 ~~~00000000010,当字符的位数超过11,它也只显示11位,如果你没有加那个让它未满11位就前面加0的参数,它不会在前面加0

声明整型数据列时,我们可以为它指定个显示宽度M(1~255),如INT(5),指定显示宽度为5个字符,如果没有给它指定显示宽度,MySQL会为它指定一个默认值。显示宽度只用于显示,并不能限制取值范围和占用空间,如:INT(3)会占用4个字节的存储空间,并且允许的最大值也不会是999,而是 INT整型所允许的最大值。

MySQL有五种整型数据列类型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。它们之间的区别是取值范围不同,存储空间也各不相同。

在整型数据列后加上UNSIGNED属性可以禁止负数,取值从0开始。

int范围

Type

Bytes

Minimum Value

Maximum Value

(Signed/Unsigned)

(Signed/Unsigned)

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

-9223372036854775808

9223372036854775807

0

18446744073709551615

MySQL中varchar最大长度是多少?

一. varchar存储规则:

4.0版本以下,varchar(20),指的是20字节,如果存放UTF8汉字时,只能存6个(每个汉字3字节)

5.0版本以上,varchar(20),指的是20字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放20个,最大大小是65532字节

Mysql4中最大也不过是20个字节,但是Mysql5根据编码不同,存储大小也不同。

二. varchar和char 的区别:

char是一种固定长度的类型,varchar则是一种可变长度的类型,它们的区别是: char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).

在MySQL中用来判断是否需要进行对据列类型转换的规则

1、在一个数据表里,如果每一个数据列的长度都是固定的,那么每一个数据行的长度也将是固定的.

2、只要数据表里有一个数据列的长度的可变的,那么各数据行的长度都是可变的.

3、如果某个数据表里的数据行的长度是可变的,那么,为了节约存储空间,MySQL会把这个数据表里的固定长度类型的数据列转换为相应的可变长度类型.例外:长度小于4个字符的char数据列不会被转换varchar类型

三.MySQL中varchar最大长度是多少?

这不是一个固定的数字。先简要说明一下限制规则。

1、限制规则

字段的限制在字段定义的时候有以下规则:

a) 存储限制

varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。

b) 编码长度限制

字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;

字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。

若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。

c) 行长度限制

导致实际应用中varchar长度限制的是一个行定义的长度。 MySQL要求一个行的定义长度不能超过65535。若定义的表长度超过这个值,则提示

ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. You have to change some columns to TEXT or BLOBs。

2、计算例子

举两个例说明一下实际长度的计算。

a) 若一个表只有一个varchar类型,如定义为

create table t4(c varchar(N)) charset=gbk;

则此处N的最大值为(65535-1-2)/2= 32766。

减1的原因是实际行存储从第二个字节开始’;

减2的原因是varchar头部的2个字节表示长度;

除2的原因是字符编码是gbk。

b) 若一个表定义为

create table t4(c int, c2 char(30), c3 varchar(N)) charset=utf8;

则此处N的最大值为 (65535-1-2-4-30*3)/3=21812

减1和减2与上例相同;

减4的原因是int类型的c占4个字节;

减30*3的原因是char(30)占用90个字节,编码是utf8。

如果被varchar超过上述的b规则,被强转成text类型,则每个字段占用定义长度为11字节,当然这已经不是“varchar”了。

则此处N的最大值为 (65535-1-2-4-30*3)/3=21812

create table t4(c int, c2 char(30), c3 varchar(21812)) ENGINE=InnoDB DEFAULT CHARSET=utf8

create table t5(c int, c2 varchar(30), c3 varchar(21812)) ENGINE=InnoDB DEFAULT CHARSET=utf8

mysql的字段长度_【mysql】字段类型和长度的解释相关推荐

  1. mysql运维技巧_​mysql初级运维使用技巧

    整理了一下,工作中用到的最高的关于mysql的一些命令和使用技巧,分享给刚接触mysql的小伙伴么. 1mysql最基础 1.1mysql安装 建议新人安装mysql直接使用yum安装即可,大牛们已经 ...

  2. python字符串最大长度_字符串String的最大长度

    开篇三个问题 作为Java的程序员,不知道在Java代码中定义了多少个字符串,可是看看下面3个问题.你是否认真思考过?是否动手实践过? 1.Java中的字符串String的最大长度是多少? 2.Ecl ...

  3. c 获取char*的长度_最大的 String 字符长度是多少?

    点击上方"武培轩",选择"设为星标" 技术文章第一时间送达! String 类可以说是在 Java 中使用最频繁的类了,就算是刚刚接触 Java 的初学者也不会 ...

  4. mysql单价乘以数量_数据库字段中存储的数据数量乘以不同单价的和的算法示例...

    数据库字段中存储的数据数量乘以不同单价的和的算法,适用于记账本程序的计件数据记录,和商品记录等场景. 代码示例如下: //模拟数据库结果集 $arr = array( array( "id& ...

  5. mysql varchar char转换_关于char 类型转 varchar类型的问题

    你的位置: 问答吧 -> MySQL -> 问题详情 关于char 类型转 varchar类型的问题 由于想把表设计为静态的表,所以牺牲了一点空间,有两个字段使用了char(40),导致使 ...

  6. mysql user 用户名长度_为什么注册的用户账号长度不能超过5个字符

    注册程序如下,IIS6.02K3数据库是MYSQLODBC是最新版当新用户注册时,LOGINID长度不让超过5个字符,实际上数据库中这个字段是20个字符长库LOGINID=trim(request(& ...

  7. mysql索引 钱缀_-MySQL索引背后的数据结构及算法原理--索引选择性与前缀索引

    既然索引可以加快查询速度,那么是不是只要是查询语句需要,就建上索引?答案是否定的.因为索引虽然加快了查询速度,但索引也是有代价的:索引文件本身要消耗存储空间,同时索引会加重插入.删除和修改记录时的负担 ...

  8. mysql毫秒转分钟_[MYSQL]时间毫秒数转换

    java中常用bigint字段保存时间,通常将时间保存为一大串数字,每次取出需要在程序里转换,有时候程序里不方便,可以使用MYSQL自带的函数FROM_UNIXTIME(unix_timestamp, ...

  9. mysql utf8 bin设置_[mysql]修改collation为utf8_bin

    mysql默认字段值区分大小写: character-set-server=utf8 collation-server=utf8_bin init-connect='SET NAMES utf8;' ...

  10. mysql查询选课数_[MySQL]查询学生选课的情况(二)

    上一篇文章使用了自定义的函数查找出来选择Math,或者选择Chinese或选择Japanese课程的学生. mysql> select * from student_course where i ...

最新文章

  1. 无人机数车--Drone-based Object Counting by Spatially Regularized Regional Proposal Network
  2. Native wifi API使用
  3. 【Hibernate步步为营】--(一对多映射)之双向关联
  4. window如何杀掉java进程_windows下java -jar 后台运行以及杀死后台进程的操作
  5. (深入.Net平台和C#编程)第七章.上机练习.20170412
  6. leetcode 1720. 解码异或后的数组(位运算)
  7. Linq:使用Take和Skip实现分页
  8. 值得关注!2021音视频人才成长路线图发布了
  9. Oracle:ODP.NET Managed 小试牛刀
  10. 解读 Kotlin/Native 技术预览版
  11. springboot生成包含特定数字_关于Spring Boot 这可能是全网最好的知识点总结
  12. 模拟定位工具gps mock
  13. 利用Epplus将数据导出到Excel
  14. 打开计算机硬盘是个磁盘图标 不显示大小,硬盘图标显示异常的解决办法
  15. linux清理缓存和垃圾,CentOS等Linux系统如何清理系统垃圾和日志?
  16. 《JAVA中的集合框架》
  17. 2023 USAMO(美国数学奥林匹克)试题答案解析
  18. 利用H5的canvas画一个时钟
  19. pip的基本命令和使用
  20. MySQL主键约束(PRIMARY KEY ,PK)

热门文章

  1. 0918类对象重载,作业2
  2. 职场中几个最忌讳的行为模式。
  3. C++-实现matlab的meshgird(OpenCV)
  4. 4 转推流格式_网络互联互通直播系统 分会场直播一体机 各地连线直播推流
  5. matlab 线性规划求最大值,MATLAB求解线性规划(含整数规划和01规划)问题.pdf
  6. 常见问题_轴承零件加工常见问题?
  7. 吐血整理,2021年最新【阿里、头条、美团】【软件测试】面试题(持续更新!)
  8. java 开发 加固态_搭建一个完整的Java开发环境
  9. 高斯低通滤波 matlab_一维和二维高斯函数及其一阶和二阶导数
  10. Android/ios手机销售榜信息