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

MySQL的实战系列:大字段如何优化

MySQL的实战系列:大字段如何优化 # 背景 线上发现一张表,1亿的数据量,物理大小尽然惊人的大,1.2T 最终发现,原来有很多字段,10个VARCHAR,1个文本 这么大的表,会给运维带来很大的痛苦...0x20 规范中:对字符和VARCHAR可以不做要求 varchar(N):255 vs 256 当实际长度大于255的时候,变长字段长度列表需要用两个字节存储,也就意味着每一行数据都会增加...所以:varchar(9000)或者varchar(3000)+ varchar(3000)+ varchar(3000),当实际长度大于8k的时候,就会溢出 所以:Blob ,文字,一行数据如果实际长度大于...8K会溢出,如果实际长度小于8K则不会溢出,并非所有的斑点,文本都会溢出 多列总和大字段vs一列大字段 多个大字段会导致多次关闭页 root:test> show create table t...Header: 1 B-tree Node: 1 File Segment inode: 1 如何对大字段进行优化 如果有多个大字段,尽量序列化后,存储在同一列中,避免多次off-page

5.2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql longtext_MySql中LongText类型大字段查询优化

    有一个longtext字段,用于存储长文本,仅万条数据,InnoDB存储文件就达G级,由于是一个小项目,受限于服务器与运维人员水平,不适合使用hdfs,MongoDB等拓展技术栈来解决这种问题,因此直接对mysql...涉及mysql基础知识 一、innodb存储引擎的处理方式 1.mysql在操作数据的时候,以page为单位 不管是更新,插入,删除一行数据,都需要将那行数据所在的page读到内存中,然后在进行操作,这样就存在一个命中率的问题...,树底层的叶子节点为一双向链表,因此每个页中至少应该有两行记录,这就决定了innodb在存储一行数据的时候不能够超过8k,但事实上应该更小,有一些InnoDB内部数据结构要存储以及预留操作空间, 3.blob...,text大字段 innodb只会存放前768字节在数据页中,而剩余的数据则会存储在溢出中(发生溢出情况的时候适用),最大768字节的作用是便于创建前缀索引/prefix index,其余更多的内容存储在额外的...因此,所有列长度越短越好 4.扩展存储禁用了自适应哈希 因为需要完整的比较列的整个长度,才能发现是不是正确的数据(哈希帮助InnoDB非常快速的找到“猜测的位置”,但是必须检查“ 发布者:全栈程序员栈长

    3.9K20

    迪B课堂 | 深入浅出解读MySQL数据行溢出

    ①compact 如果blob列值长度  768字节,那么前768字节依然在数据页...上面讲的blob或变长大字段类型包括blob、text、varchar,其中varchar列值长度大于某数N时也会存在溢出页,在latin1字符集下N值可以这样计算:innodb的块大小默认为16kb,...②compressed或dynamic 对blob采用完全行溢出,即聚集索引记录(数据页)只保留20字节的指针,指向真实存放它的溢出地址: ?...五、DBbrain如何轻松处理 数据库智能管家DBbrain对于用户在数据库中使用BLOB这类变长大字段类型也会根据具体场景给出如下优先建议,帮助用户更好的规避一些由于变长大字段带来的业务问题。...把大字段用COMPRESS()压缩后再存为BLOB,或者在发送到MySQL前在应用程序中进行压缩,可以获得显著的空间优势和性能收益。 5.

    1.2K20

    MySQL经典案例分析】关于数据行溢出由浅至深的探讨

    ①compact 如果blob列值长度 768字节,那么前768...字节依然在数据页,而剩余的则放在溢出页(off-page),如下图: 8.jpg         上面讲的blob或变长大字段类型包括blob、text、varchar,其中varchar列值长度大于某数...②compressed或dynamic 对blob采用完全行溢出,即聚集索引记录(数据页)只保留20字节的指针,指向真实存放它的溢出地址: 9.jpg          dynamic行格式,列存储是否放到...最后参考了《高性能MySQL》,给出一些使用BLOB这类变长大字段类型的建议:           ①大字段在InnoDB里可能浪费大量空间。...④把大字段用COMPRESS()压缩后再存为BLOB,或者在发送到MySQL前在应用程序中进行压缩,可以获得显著的空间优势和性能收益。

    2.9K70

    MySQLBLOB和TEXT类型学习--MySql语法

    BLOB是一个二进制大对象,可以容纳可变数量的数据。有4种BLOB类型:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。它们只是可容纳值的最大长度不同。...这些对应4种BLOB类型,有相同的最大长度和存储需求。 BLOB 列被视为二进制字符串(字节字符串)。TEXT列被视为非二进制字符串(字符字符串)。...· 对于BLOB和TEXT列的索引,必须指定索引前缀的长度。对于CHAR和VARCHAR,前缀长度是可选的。 · BLOB和TEXT列不能有 默认值。...MySQL连接程序/ODBC将BLOB值定义为LONGVARBINARY,将TEXT值定义为LONGVARCHAR。...例如,可以使用 mysql和mysqldump来更改客户端的max_allowed_packet值。 每个BLOB或TEXT值分别由内部分配的对象表示。

    2.7K10

    MySQL数据类型之TEXT与BLOB

    二者之间的主要差别是BLOB能用来保存二进制数据,比如照片;而TEXT只能保存字符数据,比如一遍文章或日记。...TEXT和BLOB中又分别包括TEXT,MEDIUMTEXT,LONGTEXT和BLOB,MEDIUMBLOB,LONGBLOB三种不同的类型,他们之间的主要区别是存储文本长度不用和存储字节不用,用户应该根据实际情况选择能够满足需求的最小存储类型...可以使用合成的(Synthetic)索引来提高大文本字段(BLOB或TEXT)的查询性能。...合成的散列索引对于那些BLOB或TEXT数据列特别有用。用散列标识符值查找的速度比搜索BLOB列的本身速度快很多。 创建一张表,来介绍合成索引的使用方法。 ?...在不必要的时候避免检索大型的BLOB或TEXT值。 把BLOB或TEXT列分离到单独的表中。

    3.6K30

    Mysql覆盖索引_mysql索引长度限制

    只扫描索引而无需回表的优点: 1.索引条目通常远小于数据行大小,只需要读取索引,则mysql会极大地减少数据访问量。...,但不是整个查询涉及的字段,mysql5.5和之前的版本也会回表获取数据行,尽管并不需要这一行且最终会被过滤掉。...2.mysql不能在索引中执行LIke操作。mysql能在索引中做最左前缀匹配的like比较,但是如果是通配符开头的like查询,存储引擎就无法做比较匹配。...这种情况下mysql只能提取数据行的值而不是索引值来做比较 优化后SQL:添加索引(artist,title,prod_id),使用了延迟关联(延迟了对列的访问) 说明:在查询的第一阶可以使用覆盖索引...记录自己对mysql的一些总结 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179723.html原文链接:https://javaforall.cn

    7.9K30

    InnoDB行格式 innodb_file_format 介绍

    InnoDB行格式 innodb_file_format 对TEXT/BLOB的影响:     摘录自:         http://seanlook.com/2016/05/18/mysql-blob-row_format...http://blog.opskumu.com/mysql-blob.html   # MySQL大字段溢出导致数据回写失败 2.1 compact     在 Antelope 两种行格式下,如果blob...(off-page)     上面所讲的讲的blob或变长大字段类型包括blob,text,varchar,其中varchar列值长度大于某数N时也会存溢出页,在latin1字符集下N值可以这样计算:innodb...我们知道对于InnoDB来说,内存是极为珍贵的,如果把768字节长度blob都放在数据页,虽然可以节省部分IO,但相对来说能缓存行数就变少,也就是能缓存的索引值变少了,降低了索引效率。...2.2 dynamic     Barracuda 的两种行格式对blob采用完全行溢出,即聚集索引记录(数据页)里面只保留20字节的指针,指向真实存放它的溢出地址。

    1.1K20

    varchar有最大长度限制吗

    char 是固定长度,其单位也是字符,比如 char(10),就表示不管你给的什么值,都会被 mysql 固定保存成 10 个字符。 如果给的字符长度小于 10,那么在尾部就会自动用空格补齐。...varchar 最大长度限制 = (行最大字节数(65535) - null 标识字节数 - 长度前缀字节数(1或2)) / 字符集单字符占用最多字节数 看到这里,不知道你有没有一个疑问,为什么长度前缀...1 或 2 个字节就够用了呢,因为 2 个字节的话,2^16 = 65536,这已经超过 mysql 行最大字节数 65535 的限制了,所以 1 到 2 个字节就够用了。...那么 varchar 类型字段的最大字节数应该就是, 65535 (行最大字节数) - 255*3 (一个字符最多占 3 个字节) = 64770, 然后再减去 2 个长度前缀字节, 64770 -...2 = 64768, 最后再算出 varchar 最大字符数为 64768 / 3 = 21589.33, ##字符数21590超过最大字符数会报错 mysql> create table test4

    14.7K21

    网易MySQL微专业学习笔记(四)-实践课数据库对象

    前言 这个系列属于个人学习网易云课堂MySQL数据库工程师微专业的相关课程过程中的笔记,本篇为其“MySQL数据库对象与应用”中的MySQL数据类型相关笔记。...varcahr最大长度 一般为65535字节。 若表为一个字段,且为utf8编码,其最大能定义的长度为65535/3 TEXT 四种不同大小,支持的更多样化。...TEXT或BLOB区别 blob的主要优势是可以存储二进制数据,所以可以把图片等存成blob,而text就只能存文本,这个是他们的主要区别,另外text类型可以有字符集和排序规则,这个在blob里是没有的...数据类型-命名规范 所有表名,字段名全部使用小写字母 不同业务,表名使用不同前缀区分,比如:kaola_good,music_song、news_comment 生产环境表名字段名要有实际意义 单个子尽量使用字段全名...整型在字段长度、索引大小等方面开销更小效率更高,入邮编字段、手机号字段等 注释,每个字段必须以comment语句给出字段的作用 经常访问的大字段(如blob/text)等需要单独放到一张表中,避免降低sal

    93210

    mysql前缀索引 默认长度_如何确定前缀索引的长度

    uniq_code` (`nick_name`,`account`,`city`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=’Test’; 复制代码 原因 在MySQL5.6...在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes。...https://dev.mysql.com/doc/refman/8.0/en/create-index.html varchar(n)占用几个字节跟字符集有关系: 字符类型若为gbk,每个字符占用2个字节...所以我们经常会见到把字段设置成varchar(255)长度的,在utf8字符集下这个是最大不超过767bytes的长度了,但是并不是一定要设置成varchar(255),还是要根据业务设置每个字段的长度...,这个就是我们说的前缀索引 修改单个索引的最大长度 修改索引限制长度需要在my.ini配置文件中添加以下内容,并重启: #修改单列索引字节长度为767的限制,单列索引的长度变为3072 innodb_large_prefix

    3.6K20
    领券