位置: 编程技术 - 正文

提高MySQL中InnoDB表BLOB列的存储效率的教程(mysql in如何优化)

编辑:rootadmin

推荐整理分享提高MySQL中InnoDB表BLOB列的存储效率的教程(mysql in如何优化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql如何调优,mysql innodb 优化,mysql innodb 优化,mysql innodb 优化,mysql提高效率,提高mysql性能,提高mysql性能,mysql提高效率,内容如对您有帮助,希望把文章链接给更多的朋友!

首先,介绍下关于InnoDB引擎存储格式的几个要点:1、InnoDB可以选择使用共享表空间或者是独立表空间方式,建议使用独立表空间,便于管理、维护。启用 innodb_file_per_table 选项,5.5以后可以在线动态修改生效,并且执行 ALTER TABLE xx ENGINE = InnoDB 将现有表转成独立表空间,早于5.5的版本,修改完这个选项后,需要重启才能生效;2、InnoDB的data page默认KB,5.6版本以后,新增选项 innodb_page_size 可以修改,在5.6以前的版本,只能修改源码重新编译,但并不推荐修改这个配置,除非你非常清楚它有什么优缺点;3、InnoDB的data page在有新数据写入时,会预留1/的空间,预留出来的空间可用于后续的新纪录写入,减少频繁的新增data page的开销;4、每个data page,至少需要存储2行记录。因此理论上行记录最大长度为8KB,但事实上应该更小,因为还有一些InnoDB内部数据结构要存储;5、受限于InnoDB存储方式,如果数据是顺序写入的话,最理想的情况下,data page的填充率是/,但一般没办法保证完全的顺序写入,因此,data page的填充率一般是1/2到/。因此每个InnoDB表都最好要有一个自增列作为主键,使得新纪录写入尽可能是顺序的;6、当data page填充率不足1/2时,InnoDB会进行收缩,释放空闲空间;7、MySQL 5.6版本的InnoDB引擎当前支持COMPACT、REDUNDANT、DYNAMIC、COMPRESSED四种格式,默认是COMPACT格式,COMPRESSED用的很少且不推荐(见下一条),如果需要用到压缩特性的话,可以直接考虑TokuDB引擎;8、COMPACT行格式相比REDUNDANT,大概能节省%的存储空间,COMPRESSED相比COMPACT大概能节省%的存储空间,但会导致TPS下降了%。因此强烈不推荐使用COMPRESSED行格式;9、当行格式为DYNAMIC或COMPRESSED时,TEXT/BLOB之类的长列(long column,也有可能是其他较长的列,不一定只有TEXT/BLOB类型,看具体情况)会完全存储在一个独立的data page里,聚集索引页中只使用字节的指针指向新的page,这就是所谓的off-page,类似ORACLE的行迁移,磁盘空间浪费较严重,且I/O性能也较差。因此,强烈不建议使用BLOB、TEXT、超过长度的VARCHAR列类型;、当InnoDB的文件格式(innodb_file_format)设置为Antelope,并且行格式为COMPACT 或 REDUNDANT 时,BLOB、TEXT或者长VARCHAR列只会将其前字节存储在聚集索页中(最大字节的作用是便于创建前缀索引/prefix index),其余更多的内容存储在额外的page里,哪怕只是多了一个字节。因此,所有列长度越短越好;、在off-page中存储的BLOB、TEXT或者长VARCHAR列的page是独享的,不能共享。因此强烈不建议在一个表中使用多个长列。

综上,如果在实际业务中,确实需要在InnoDB表中存储BLOB、TEXT、长VARCHAR列时,有下面几点建议:1、尽可能将所有数据序列化、压缩之后,存储在同一个列里,避免发生多次off-page;2、实际最大存储长度低于的列,转成VARCHAR或者CHAR类型(如果是变长数据二者没区别,如果是定长数据,则使用CHAR类型);3、如果无法将所有列整合到一个列,可以退而求其次,根据每个列最大长度进行排列组合后拆分成多个子表,尽量是的每个子表的总行长度小于8KB,减少发生off-page的频率;4、上述建议是在data page为默认的KB前提下,如果修改成8KB或者其他大小,请自行根据上述理论进行测试,找到最合适的值;5、字符型列长度小于时,无论采用CHAR还是VARCHAR来存储,或者把VARCHAR列长度定义为,都不会导致实际表空间增大;6、一般在游戏领域会用到比较多的BLOB列类型,游戏界同行可以关注下。

提高MySQL中InnoDB表BLOB列的存储效率的教程(mysql in如何优化)

下面是测试验证过程,有耐心的同学可以慢慢看:

上述各个测试表都写入行记录后,再来对比下其表空间文件大小,以及重整表空间后的大小,观察碎片率。详细对比见下:

最后一种分表方式中,5个子表的表空间文件大小总和是 + + + + = 字节。可以看到,这种方式的总大小和原始表大小差距最小,其他几种存储方式都比这个来的大。

使用sysbench来测试MySQL性能的详细教程 sysbench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况。目前sysbench代码托管在launchpad上,项

探究MySQL中索引和提交频率对InnoDB表写入速度的影响 本次,我们来看看索引、提交频率对InnoDB表写入速度的影响,了解有哪些需要注意的。先直接说几个结论吧:1、关于索引对写入速度的影响:a、如果有

关于MySQL中savepoint语句使用时所出现的错误 前几天帮同事解决一个案例,在主从复制环境下,从库上的MySQL版本号是5.5.5,遇到下面的错误:#其他非相关信息我都隐藏掉了[(yejr@imysql.com)]showslavestatu

标签: mysql in如何优化

本文链接地址:https://www.jiuchutong.com/biancheng/347334.html 转载请保留说明!

上一篇:简单分析MySQL中的primary key功能(mysql的基本介绍)

下一篇:使用sysbench来测试MySQL性能的详细教程(sysbench内存性能测试)

  • 企业垃圾处理费申报依据
  • 工商注册经营部和公司的区别
  • 汇算清缴申报的时候资产总额带不出来
  • 苗圃公司会计分录
  • 服务不动产和无形资产扣除项目本期实际扣除金额
  • 国债利息收入计入财务费用吗
  • 建安行业是建筑行业吗
  • 企业所得税不超过300万怎么算
  • 未达起征点销售额怎么填申报表
  • 股份制改造而发生的资产评估增值税法规定
  • 增值税专票经办人怎么填
  • 固定资产改变用途进项转出
  • 进项与销项不符怎么办
  • 支付运费价税合计
  • 项目资本金是什么意思大白话
  • 补偿金需要缴纳个税分开
  • 金蝶用户管理怎么设置
  • 企业所得税的账载金额和实际发生额
  • 企业所得税利润总额怎么算
  • 非居民纳税人享受协定待遇办理方式
  • 期末调汇会计分录
  • 企业工商年报填错了怎么办
  • 生产经营所得个税表
  • 新准则待摊费用
  • win10高级功能
  • window10玩吃鸡总崩溃
  • 加班车费报销计入什么科目
  • 供应商自身的品质问题
  • 黄石国家公园的建立意义
  • 工资储备金制度
  • 1558伊丽莎白女王
  • 未认证用户是什么意思
  • 其他营业账簿印花税减免政策
  • 库存现金盘亏处理流程
  • 红字增值税发票怎么开具图解
  • php如何入门
  • 驱动开发做得长久吗
  • 对公账户走账是怎么回事
  • 关于小微企业免征增值税
  • 国库集中支付发送签收失败
  • sqlserver2012安装好了桌面没有图标
  • 以前年度未处理的业务
  • 企业的资产必须符合哪些条件
  • 哪些情况可以开立基本账户
  • 企业固定资产贷款二押的风险
  • 建筑公司内账收什么费用
  • 使用正则表达式提取文本(888)555
  • SQL中DATEADD和DATEDIFF的用法示例介绍
  • 个人出租商铺如何报税申报,需要什么资料
  • 小规模纳税人缴纳的增值税计入成本吗
  • 增值税销项税额抵减账务处理
  • 运输公司内账会计每天需要做什么
  • 企业账户里的政府账户
  • 建筑行业异地预缴税率
  • 以前年度损益调整会计分录
  • 公路工程投标保证金
  • 停车费发票能报餐饮费吗怎么开
  • 非流动资产基金借贷方表示
  • 银行流水账单怎么删
  • 企业开办费计入什么科目
  • 总账建账的原则包括
  • mysql的ip怎么看
  • winproxy.exe - winproxy是什么进程
  • windows7无法激活怎么解决方法
  • win10共享打印机win7连不上
  • Win10红石版Edge浏览器新扩展功能:关灯(附扩展程序使用)
  • linux如何使用命令创建文件夹
  • ie版本过低怎么升级win7
  • unity出现bug
  • 深入理解linux内核第三版
  • python标准模板库
  • nodejs test
  • windows下安装python环境
  • bootstrap-
  • 页面跳转后js还会执行吗
  • 胰腺在人体的哪个部位图解
  • 申请电子发票需要去税务局吗
  • 美国买房hoa
  • 珠海南湾国际属于香洲哪个街道
  • 房地产对外投资契税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设