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

MySQL到底能有多少字段

今天技术讨论群里 “一切随遇而安”同学看书时出现一个疑问,一个MySQL的表中到底可以有多少字段?带着这个疑问,我们展开了探讨,也接着讨论了一个单字段长度的问题。...01 官方文档说明 MySQL8.0官方文档的内容如下,主要意思是字段个数限制达不到理想的4096个,且和字段类型有关,innodb引擎的字段上限是1017,。 ?...因此,官方文档中介绍的MySQL innodb引擎表最多有1017个字段。...Error 1117: Too many columns MySQL has a limit of 2598 也就是说MySQL中MyISAM引擎表最多可以存2598个字段。...03 测试字段长度限制 大家都知道的一个知识是在MySQL中一行除了blob及text类的大字段之外,其余字段的长度之和不能超过65535,那么这个是确定的么,因此再次做一次测试。

1.1K20

MySQL的一个表最多可以有多少字段

总结 ● MySQL Server最多只允许4096个字段 ● InnoDB 最多能有1000个字段字段长度加起来如果超过65535,MySQL server层就会拒绝创建表 ● 字段长度加起来...错误1 这个报错其实我们查询MySQL官方手册就可以查询到, 对于一行记录最大的限制是65535字节。为什么是65535,不要问我,手册也没说:)——一行数据里面字段长度定义有64k,我也是醉了。...MySQL是分两层的,MySQL Server层 + 存储引擎层。 第2个问题其实是MySQL除了在Server层做了一次限制还会在Innodb存储引擎层在做一次限制。...其实MySQL在计算字段长度的时候并不是按照字段的全部长度来记的。 列字段小于40个字节的都会按实际字节计算,如果大于20 * 2=40 字节就只会按40字节。...对应到MySQL代码中storage/innobase/dict/dict0dict.cc的dict_index_too_big_for_tree()中: 也就是说,如果字段长度超过BTR_EXTERN_FIELD_REF_SIZE

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

MySQL VARCHAR(M)最多能存储多少数据

MySQL定义VARCHAR(M)最多可以是65535个字节,M表示的是「字符数量」,但是实际存储中并不能存储那么多字节。如果一个字段超过了65535个字节,可以选择使用TEXT或者BLOB类型。...VARCHAR(M)最多能存储多少真实数据(也就是M的最大取值)跟字段采用的字符集有关,以下就拿字符集utf8、gbk、utf8mb4说明一下: utf8字符集:MySQL中的utf8字符集跟标准的utf...MySQL中的utf8字符集一个字符最多占3个字节,而标准的utf-8字符集是最多占4个字节。...在字段允许为NULL的情况下,计算最多能存储多少真实数据的公式为(65535-2-1)÷3=21844,字段不允许为NULL的情况下,公式为(65535-2)÷3=21844.333,所以utf8字符集最多能存储...如果字段设置的长度超过了实际能存储的长度,MySQL就是报下面这个错误 ERROR 1118 (42000): Row size too large.

84820

VARCHAR 最多多少个字符?|mysql系列(3)

前言 上篇《VARCHAR(M) 到底占用多少个字节?|mysql系列(2)》分享了VARCHAR(M) 占用多少个字节,那VARCHAR 最大能存多少个字符呢?...|mysql 系列(1)》一文中讲到,MySQL服务器上负责对表中数据的读取和落盘(即写入磁盘)工作是由存储引擎 完成的。InnoDB是一个将表中的数据存储到磁盘上的存储引擎 。...这也是mysql 持久化的保证。插入的数据记录在磁盘上的存放方式被称为行格式或者记录格式。Mysql 目前有4种行格式:Redundant、Compact、Dynamic、Compressed....记录的额外信息 记录的额外信息包括:变长字段长度列表、NULL值列表和记录头信息。...变长字段长度列表: 比如VARCHAR(M)、VARBINARY(M)、各种TEXT类型,各种BLOB类型,把拥有这些数据类型的列称为变长字段 ; 变长字段占用的存储空间分为两部分: 真正的数据内容

1.8K20

MySQL的timestamp字段可以使用的范围是多少

我在做一个收据采集的程序,需要记录起始时间和结束时间,在数据库中是用timestamp字段来保存的,有些情况下不存在起始时间,此时就需要设置一个默认的起始时间,当初想着是使用timestamp类型的『最小值...从MySQL的官方文档就可以得到结论,http://dev.mysql.com/doc/refman/5.0/en/datetime.html The TIMESTAMP data type is used...MySQL converts TIMESTAMP values from the current time zone to UTC for storage, and back from UTC to the...For more information, see Section 10.6, “MySQL Server Time Zone Support”....如果我没有理解错的话,MySQL将timestamp类型的值保存的时候,会从当前时区转成UTC时间,正好解释了前面1970-01-01 00:00:00或1970-01-01 00:00:01两个值保存时出错的问题了

2.3K20

MySQL|查询字段数量多少对查询效率的影响

二、简单的流程介绍 下面我主要结合字段多少和全表扫描2个方面做一个简单的流程介绍。...通过 select 字段构建 readset(MySQL 层) 首先需要构建一个叫做 read_set 的位图,来表示访问的字段位置及数量。...初次访问定位的时候还会构建一个模板(mysql_row_templ_t)(Innodb 层) 本模板主要用于当 Innodb 层数据到 MySQL 层做转换的时候使用,其中记录了使用的字段数量、字段的字符集...但是需要注意的是,这里构建模板就会通过我们上面说的 read_set 去判断到底有多少字段需要构建到模板中,然后才会调用 build_template_field 函数。...三、回到问题本身 好了到这里我们大概知道全表扫描的访问数据的流程了,我们就来看看一下在全表扫描流程中字段多少到底有哪些异同点: 不同点: 构建的 read_set 不同,字段越多 read_set

5.6K20

mysql密码字段类型_MySQL 字段类型

unsigned 和 zerofill UNSIGNED 修饰符规定字段只保存正值,即无符号,而mysql字段默认是有符号的。...因为 VARCHAR 类型可以根据实际内容动态改变存储值的长度,所以在不能确定字段需要多少字符时使用 VARCHAR 类型可以大大地节约磁盘空间、提高存储效率。...一个 ENUM 类型最多可以包含 65536 个元素,其中一个元素被 MySQL 保留,用来存储错误信息,这个错误值用索引 0 或者一个空字符串表示。...如果插入一个即有合法的元素又有非法的元素的记录,MySQL 将会保留合法的元素,除去非法的元素。 一个 SET 类型最多可以包含 64 项元素。...,当日热门,生日多少天等等逻辑 不要使用null 为什么这么说呢,因为MYSQL对NULL字段索引优化不佳,增加更多的计算难度,同时在保存与处理NULL类形时,也会做更多的工作,所以从效率上来说,不建议用过多的

14.4K20
领券