位置: 编程技术 - 正文

详解MySQL性能优化(二)(mysql的性能调优)

编辑:rootadmin

推荐整理分享详解MySQL性能优化(二)(mysql的性能调优),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql性能极限,mysql性能差,mysql性能如何,mysql性能极限,mysql的性能调优,mysql的性能优化,mysql性能比较,mysql性能比较,内容如对您有帮助,希望把文章链接给更多的朋友!

七、MySQL数据库Schema设计的性能优化高效的模型设计

适度冗余-让Query尽两减少Join

大字段垂直分拆-summary表优化

大表水平分拆-基于类型的分拆优化

统计表-准实时优化

合适的数据类型

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_d.jpg" alt="查看图片" />

时间存储格式总类并不是太多,我们常用的主要就是DATETIME,DATE和TIMESTAMP这三种了。从存储空间来看TIMESTAMP最少,四个字节,而其他两种数据类型都是八个字节,多了一倍。而TIMESTAMP的缺点在于他只能存储从年之后的时间,而另外两种时间类型可以存放最早从年开始的时间。如果有需要存放早于年之前的时间的需求,我们必须放弃TIMESTAMP类型,但是只要我们不需要使用年之前的时间,最好尽量使用TIMESTAMP来减少存储空间的占用。

字符存储类型

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_df.jpg" alt="查看图片" />

CHAR[(M)]类型属于静态长度类型,存放长度完全以字符数来计算,所以最终的存储长度是基于字符集的,如latin1则最大存储长度为字节,但是如果使用gbk则最大存储长度为字节。CHAR类型的存储特点是不管我们实际存放多长数据,在数据库中都会存放M个字符,不够的通过空格补上,M默认为1。虽然CHAR会通过空格补齐存放的空间,但是在访问数据的时候,MySQL会忽略最后的所有空格,所以如果我们的实际数据中如果在最后确实需要空格,则不能使用CHAR类型来存放。

VARCHAR[(M)]属于动态存储长度类型,仅存占用实际存储数据的长度。TINYTEXT,TEXT,MEDIUMTEXT和LONGTEXT这四种类型同属于一种存储方式,都是动态存储长度类型,不同的仅仅是最大长度的限制。

事务优化

1. 脏读:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。

2. 不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。

3. 幻读:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。

Innodb在事务隔离级别方面支持的信息如下:

1.READ UNCOMMITTED

常被成为Dirty Reads(脏读),可以说是事务上的最低隔离级别:在普通的非锁定模式下SELECT的执行使我们看到的数据可能并不是查询发起时间点的数据,因而在这个隔离度下是非Consistent Reads(一致性读);

2.READ COMMITTED

这一隔离级别下,不会出现DirtyRead,但是可能出现Non-RepeatableReads(不可重复读)和PhantomReads(幻读)。

3. REPEATABLE READ

REPEATABLE READ隔离级别是InnoDB默认的事务隔离级。在REPEATABLE READ隔离级别下,不会出现DirtyReads,也不会出现Non-Repeatable Read,但是仍然存在PhantomReads的可能性。

4.SERIALIZABLE

SERIALIZABLE隔离级别是标准事务隔离级别中的最高级别。设置为SERIALIZABLE隔离级别之后,在事务中的任何时候所看到的数据都是事务启动时刻的状态,不论在这期间有没有其他事务已经修改了某些数据并提交。所以,SERIALIZABLE事务隔离级别下,PhantomReads也不会出现。

八、可扩展性设计之数据切分

数据的垂直切分

数据的垂直切分,也可以称之为纵向切分。将数据库想象成为由很多个一大块一大块的“数据块”(表)组成,我们垂直的将这些“数据块”切开,然后将他们分散到多台数据库主机上面。这样的切分方法就是一个垂直(纵向)的数据切分。

垂直切分的优点

详解MySQL性能优化(二)(mysql的性能调优)

◆数据库的拆分简单明了,拆分规则明确;

◆应用程序模块清晰明确,整合容易;

◆数据维护方便易行,容易定位;

垂直切分的缺点

◆部分表关联无法在数据库级别完成,需要在程序中完成;

◆对于访问极其频繁且数据量超大的表仍然存在性能平静,不一定能满足要求;

◆事务处理相对更为复杂;

◆切分达到一定程度之后,扩展性会遇到限制;

◆过读切分可能会带来系统过渡复杂而难以维护。

数据的水平切分

数据的垂直切分基本上可以简单的理解为按照表按照模块来切分数据,而水平切分就不再是按照表或者是功能模块来切分了。一般来说,简单的水平切分主要是将某个访问极其平凡的表再按照某个字段的某种规则来分散到多个表之中,每个表中包含一部分数据。

水平切分的优点

◆表关联基本能够在数据库端全部完成;

◆不会存在某些超大型数据量和高负载的表遇到瓶颈的问题;

◆应用程序端整体架构改动相对较少;

◆事务处理相对简单;

◆只要切分规则能够定义好,基本上较难遇到扩展性限制;

水平切分的缺点

◆切分规则相对更为复杂,很难抽象出一个能够满足整个数据库的切分规则;

◆后期数据的维护难度有所增加,人为手工定位数据更困难;

◆应用系统各模块耦合度较高,可能会对后面数据的迁移拆分造成一定的困难。

数据切分与整合中可能存在的问题

1.引入分布式事务的问题

完全可以将一个跨多个数据库的分布式事务分拆成多个仅处于单个数据库上面的小事务,并通过应用程序来总控各个小事务。当然,这样作的要求就是我们的俄应用程序必须要有足够的健壮性,当然也会给应用程序带来一些技术难度。

2.跨节点Join的问题

推荐通过应用程序来进行处理,先在驱动表所在的MySQLServer中取出相应的驱动结果集,然后根据驱动结果集再到被驱动表所在的MySQL Server中取出相应的数据。

3.跨节点合并排序分页问题

从多个数据源并行的取数据,然后应用程序汇总处理。

九、可扩展性设计之Cache与Search的利用

通过引入Cache(Redis、Memcached),减少数据库的访问,增加性能。

通过引入Search(Lucene、Solr、ElasticSearch),利用搜索引擎高效的全文索引和分词算法,以及高效的数据检索实现,来解决数据库和传统的Cache软件完全无法解决的全文模糊搜索、分类统计查询等功能。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_db4c.jpg" alt="查看图片" />

标签: mysql的性能调优

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

上一篇:详解MySQL性能优化(一)(mysql性能极限)

下一篇:MySql存储过程与函数详解(MySQL存储过程与触发器)

  • 增值税开票软件客服电话
  • 小规模纳税人不开票需要纳税吗
  • 房地产企业成本包括哪些
  • 个人所得税申报密码如何设置
  • 发票号码代码不合法
  • 个税缴款三方协议
  • 银行理财怎么做才能赚钱
  • 房屋租赁收入如何征税?
  • 商贸企业涉税问题
  • 出口企业享受增值税优惠政策
  • 年终奖和工资个人所得税计算器
  • 居民企业技术转让所得税优惠政策
  • 机动车发票抵扣联有什么用
  • 营改增后印花税计税依据文件
  • 汽车修理厂可以安装车牌吗
  • 附加税水利行政事业是否取消?
  • 职工福利费包括五险一金吗
  • 信托公司如何投资
  • 预警期内的应收账款管理
  • 制造费用可以直接转入本年利润吗
  • 企业收到待清算的现金
  • 出租车车票能进高铁站吗
  • 金税三期核心征管系统行政处罚
  • 无形资产的出租租金通过什么科目核算
  • 购货方跨月销项负数发票如何做账?
  • 如何查看系统浏览器记录
  • 营业外收入怎么做会计凭证
  • 服务成本怎么处理
  • php文件锁并发 性能
  • 收到某公司的钱的会计分录
  • 支付货款的流程
  • PHP:pg_lo_open()的用法_PostgreSQL函数
  • 采用权益法核算
  • 运行安装程序时发生错误
  • 销售地下车库缴纳哪些税
  • yolov5 anchors 中 K-means聚类
  • 资产总额怎么计算公式
  • video.js教程
  • phpgd库怎么开
  • discuz如何关闭站点
  • 刷题笔贴吧
  • 企业坏账准备贷方核算内容
  • 员工垫付公司的保险费
  • 缴纳上年汇算清缴的分录
  • 国家研发费用补助
  • 企业增资会计科目
  • 哪些增值税可以免税
  • 国债收入要交企业所得税吗
  • 核定征收适用于什么税率
  • 实收资本认缴如何做账
  • 购买的电子承兑公司怎么平账做收据
  • 海关进口增值税专用缴款书在哪里打印
  • 成本大于收入汇算清缴怎么处理
  • 小型微利企业减按25%计算应纳税所得额
  • 弃置费用的摊销计算
  • 金税盘技术维护费
  • 逾期纳税申报会被罚款吗
  • 固定资产清理费用账务处理
  • win8系统怎样安装
  • ghost安装盘的制作
  • windows10玩lol有延迟怎么办
  • 忘记mysql密码
  • 安全账户管理器或本地安全机构服务器
  • 苹果发布新机老款能降多少
  • pcalc是什么软件
  • win7如何查询电脑使用记录
  • linux病毒排查
  • 如何解决windows不是正版的问题
  • 深入解析windows第7版
  • unsupportedclassversion
  • cocos2djs
  • shell脚本编写 方法
  • unity物理效果
  • cocos-2dx
  • javascript高级程序设计pdf下载
  • python文件操作方法
  • 蛋哥的日常
  • android网络框架okhttp
  • 失业金存在多个账户
  • 国税软件下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设