问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

int最大长度是多少,MySQL中varchar最大长度是多少

发布网友 发布时间:2022-04-21 15:09

我来回答

1个回答

热心网友 时间:2023-10-07 20:36



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

varchar(30)和char(30)最多能存放:

工在基工左基工在基顺工作奔大规模集成电路城工作东奔西走左夺工城鞯革城载模压地工魂牵梦萦栽土木工程魂牵梦萦栽植奇巧魂牵梦萦地厅城柑模压东奔西走苦村落模压革革柑可耕地村模压基栽魂牵梦基

aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa

aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa

111111111111111111111111111111111111111111111111111111

111111111111111111111111111111111111
int(11)最大长度是多少,MySQL中varchar最大长度是多少(转)
标签:

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
在excel中输入产品序号如何直接引出相应的信息 excel表格输序号自动出现内容 戏剧教育主要学什么内容 戏剧教育专业就业前景和就业方向怎么样 戏剧教育专业学什么 2025就业前景怎么样 戏剧教育学什么 戏剧教育专业是本科还是专科 戏剧教育专业要读多少年 戏剧教育是什么专业 贵州省合医在浙江省能直接报销吗 求英语翻译!急! 怎样指定int类型的长度?? 麻烦各位高手帮忙翻译一下,谢谢啦! java中int型最大值是多少 苹果笔记本电脑内存多大够了? 在C#中怎么定义int的长度 用来满足基本办公用的苹果电脑最少内存要多大呢? 英语翻译三句话 用来满足基本办公用的苹果电脑最少内存要多大呢? c语言 int 大小 急!英语翻译 苹果电脑128g和256g选哪个 MySQL数据库中 int 长度最大是多少 “look back and remember”这句话是什么意思? 苹果笔记本电脑内存分别是多少G MySQL中int最大长度是多少 苹果电脑有多大内存 跪求英语高手帮忙翻译一下这段话,论文急用。 帮我中译英~1个句子而已~谢谢各位。。。。 C语言一个int型到底可以表示多大的数字 英语翻译-三句话 英特尔E5700这款CPU怎么样 E5700CpU怎么样? e5700属于几代cpu e5700 cpu参数是多少? 奔腾e5700处理器怎么样? 我的电脑cpu是e5700,现在是单条2g ddr3 CPU E5700好还是E8400 E5700 @3.00GHZ 是什么意思,其中E5700是什么意思 ,3.00GHZ又是什么意思呀,我是新手,麻烦哪位大侠指点 Intel 奔腾双核 E5700怎么样?比i3差些什么? 双核E5700是什么意思? E5700 CPU 的倍频不断变化怎么办? 为什么我吧cpu换成e5700了为什么电脑还是显示我以前那个cpu 英特尔E5700和E6500的CPU有什么区别,那款更好 pentium r dual-core cpu e5700与 e6500的区别 Pentium(R) Dual-Core CPU E5700 @3.00GHZ 2.99GHZ各代表什么 电脑升级问题!纠结啊!到底是买E5400还是E5700啊!我很纠结啊!到底哪个CPU好啊! CPU Intel 奔腾双核 E5500好还是E5700好呢? 奔腾双核E5700cpu配什么主板 CPU intel 奔腾4 和 E5700 哪个更高 更好