位置: 编程技术 - 正文

Mysql数据库性能优化一(MySQL数据库性能优化)

编辑:rootadmin

推荐整理分享Mysql数据库性能优化一(MySQL数据库性能优化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql数据库性能优化方法有哪些,mysql数据库性能监控工具,mysql数据库性能优化方法,MySQL数据库性能监控及调优,MySQL数据库性能诊断产品DBdoctor介绍,MySQL数据库性能监控及调优,MySQL数据库性能优化,mysql数据库性能调优,内容如对您有帮助,希望把文章链接给更多的朋友!

今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显。关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情。当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能。这里,我们不会讲过多的SQL语句的优化,而只是针对MySQL这一Web应用最多的数据库。

mysql的性能优化无法一蹴而就,必须一步一步慢慢来,从各个方面进行优化,最终性能就会有大的提升。

Mysql数据库的优化技术

对mysql优化是一个综合性的技术,主要包括

&#;表的设计合理化(符合3NF)

&#;添加适当索引(index) [四种: 普通索引、主键索引、唯一索引unique、全文索引]

&#;分表技术(水平分割、垂直分割)

&#;读写[写: update/delete/add]分离

&#;存储过程 [模块化编程,可以提高速度]

&#;对mysql配置优化 [配置最大并发数my.ini, 调整缓存大小 ]

&#;mysql服务器硬件升级

&#;定时的去清除不需要的数据,定时进行碎片整理(MyISAM)

数据库优化工作

对于一个以数据为中心的应用,数据库的好坏直接影响到程序的性能,因此数据库性能至关重要。一般来说,要保证数据库的效率,要做好以下四个方面的工作:

① 数据库设计

② sql语句优化

③ 数据库参数配置

④ 恰当的硬件资源和操作系统

此外,使用适当的存储过程,也能提升性能。

这个顺序也表现了这四个工作对性能影响的大小

数据库表设计

通俗地理解三个范式,对于数据库设计大有好处。在数据库设计中,为了更好地应用三个范式,就必须通俗地理解三个范式(通

俗地理解是够用的理解,并不是最科学最准确的理解):

第一范式:1NF是对属性的原子性约束,要求属性(列)具有原子性,不可再分解;(只要是关系型数据库都满足1NF)

第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;

第三范式:3NF是对字段冗余性的约束,它要求字段没有冗余。 没有冗余的数据库设计可以做到。

但是,没有冗余的数据库未必是最好的数据库,有时为了提高运行效率,就必须降低范式标准,适当保留冗余数据。具体做法是: 在概念数据模型设计时遵守第三范式,降低范式标准的工作放到物理数据模型设计时考虑。降低范式就是增加字段,允许冗余。

&#; 数据库的分类

关系型数据库: mysql/oracle/db2/informix/sysbase/sql server

非关系型数据库: (特点: 面向对象或者集合)

NoSql数据库: MongoDB(特点是面向文档)

举例说明什么是适度冗余,或者说有理由的冗余!

上面这个就是不合适的冗余,原因是:

在这里,为了提高学生活动记录的检索效率,把单位名称冗余到学生活动记录表里。单位信息有条记录,而学生活动记录在

一年内大概有万数据量。 如果学生活动记录表不冗余这个单位名称字段,只包含三个int字段和一个timestamp字段,只占用了字节,是一个很小的表。而冗余了一个 varchar()的字段后则是原来的3倍,检索起来相应也多了这么多的I/O。而且记录数相差悬殊, VS ,导致更新一个单位名称还要更新条冗余记录。由此可见,这个冗余根本就是适得其反。

订单表里面的Price就是一个冗余字段,因为我们可以从订单明细表中统计出这个订单的价格,但是这个冗余是合理的,也能提升查询性能。

从上面两个例子中可以得出一个结论:

1---n 冗余应当发生在1这一方.

SQL语句优化

SQL优化的一般步骤

1.通过show status命令了解各种SQL的执行频率。

2.定位执行效率较低的SQL语句-(重点select)

3.通过explain分析低效率的SQL

4.确定问题并采取相应的优化措施

SQL语句优化-show参数

MySQL客户端连接成功后,通过使用show [session|global] status 命令可以提供服务器状态信息。其中的session来表示当前的连接的统计结果,global来表示自数据库上次启动至今的统计结果。默认是session级别的。

下面的例子:

show status like 'Com_%';

其中Com_XXX表示XXX语句所执行的次数。

重点注意:Com_select,Com_insert,Com_update,Com_delete通过这几个参数,可以容易地了解到当前数据库的应用是以插入更新为主还是以查询操作为主,以及各类的SQL大致的执行比例是多少。

还有几个常用的参数便于用户了解数据库的基本情况。

Connections:试图连接MySQL服务器的次数

Uptime:服务器工作的时间(单位秒)

Slow_queries:慢查询的次数 (默认是慢查询时间s)

如何查询mysql的慢查询时间

修改mysql 慢查询时间

SQL语句优化-定位慢查询

问题是: 如何从一个大项目中,迅速的定位执行速度慢的语句. (定位慢查询)

首先我们了解mysql数据库的一些运行状态如何查询(比如想知道当前mysql运行的时间/一共执行了多少次

select/update/delete.. / 当前连接)

为了便于测试,我们构建一个大表( 万)-> 使用存储过程构建

默认情况下,mysql认为秒才是一个慢查询.

修改mysql的慢查询.

构建大表->大表中记录有要求, 记录是不同才有用,否则测试效果和真实的相差大.创建:

Mysql数据库性能优化一(MySQL数据库性能优化)

测试数据

为了存储过程能够正常执行,我们需要把命令执行结束符修改delimiter $$创建函数,该函数会返回一个指定长度的随机字符串

创建一个存储过程

这时我们如果出现一条语句执行时间超过1秒中,就会统计到.

如果把慢查询的sql记录到我们的一个日志中

在默认情况下,低版本的mysql不会记录慢查询,需要在启动mysql时候,指定记录慢查询才可以

binmysqld.exe - -safe-mode - -slow-query-log [mysql5.5 可以在my.ini指定]

binmysqld.exe ?log-slow-queries=d:/abc.log [低版本mysql5.0可以在my.ini指定]

该慢查询日志会放在data目录下[在mysql5.0这个版本中时放在 mysql安装目录/data/下],在 mysql5.5.下是需要查看

my.ini 的 datadir="C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.5/Data/“来确定.

在mysql5.6中,默认是启动记录慢查询的,my.ini的所在目录为:C:ProgramDataMySQLMySQL Server 5.6,其中有一个配置项

slow-query-log=1

针对 mysql5.5启动慢查询有两种方法

binmysqld.exe - -safe-mode - -slow-query-log

也可以在my.ini 文件中配置:

通过慢查询日志定位执行效率较低的SQL语句。慢查询日志记录了所有执行时间超过long_query_time所设置的SQL语句。

为dept表添加数据

****测试语句***[对emp表的记录可以为 ,效果很明显慢]

如果带上order by e.empno 速度就会更慢,有时会到1min多.

测试语句

查看慢查询日志:默认为数据目录data中的host-name-slow.log。低版本的mysql需要通过在开启mysql时使用- -log-slow-queries[=file_name]来配置

SQL语句优化-explain分析问题

会产生如下信息:

select_type:表示查询的类型。

table:输出结果集的表

type:表示表的连接类型

possible_keys:表示查询时,可能使用的索引

key:表示实际使用的索引

key_len:索引字段的长度

rows:扫描出的行数(估算的行数)

Extra:执行情况的描述和说明

explain select * from emp where ename='JKLOIP'

如果要测试Extra的filesort可以对上面的语句修改

EXPLAIN详解

id

SELECT识别符。这是SELECT的查询序列号

id 示例

select_type

PRIMARY :子查询中最外层查询

SUBQUERY : 子查询内层第一个SELECT,结果不依赖于外部查询

DEPENDENT SUBQUERY:子查询内层第一个SELECT,依赖于外部查询

UNION :UNION语句中第二个SELECT开始后面所有SELECT,

SIMPLE

UNION RESULT UNION 中合并结果

Table

显示这一步所访问数据库中表名称

Type

对表访问方式

ALL:

完整的表扫描 通常不好

system:表仅有一行(=系统表)。这是const联接类型的一个特

const:表最多有一个匹配行

Possible_keys

该查询可以利用的索引,如果没有任何索引显示 null

Key

Mysql 从 Possible_keys 所选择使用索引

Rows

估算出结果集行数

Extra

查询细节信息

No tables :Query语句中使用FROM DUAL 或不含任何FROM子句

Using filesort :当Query中包含 ORDER BY 操作,而且无法利用索引完成排序,

Impossible WHERE noticed after reading const tables: MYSQL Query Optimizer

通过收集统计信息不可能存在结果

Using temporary:某些操作必须使用临时表,常见 GROUP BY ; ORDER BY

Using where:不用读取表中所有信息,仅通过索引就可以获取所需数据;

以上所述是小编给大家介绍的Mysql数据库性能优化一 ,下篇文章继续给大家介绍mysql数据库性能优化二,希望大家持续关注本站最新内容!

Mysql数据库性能优化二 在上篇文章给大家介绍了mysql数据库性能优化一,今天继续接着上篇文章给大家介绍数据库性能优化相关知识。具体内容如下所示:建立适当的索引说起

Mysql创建通用设备管理信息系统数据库 下面通过图文并茂的方式给大家介绍通用设备管理信息系统数据库的创建过程,具体详情请看下文。设备表:id,名称,类别,型号,投运日期,购入日

MySQL中数据类型的验证 CHARchar(M)M字符,长度是M*字符编码长度,M最大。验证如下:mysqlcreatetablet1(namechar())defaultcharset=utf8;ERROR():Columnlengthtoobigforcolumn'name'(max=);useBLO

标签: MySQL数据库性能优化

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

上一篇:详解MySQL数据库insert和update语句(mysql数据库简单介绍)

下一篇:Mysql数据库性能优化二(mysql数据库性能优化方法有哪些)

  • 公司买房子可以贷款多少
  • 受托代销商品款和受托代销商品的区别
  • 小规模未开票收入填在哪里
  • 出差的餐饮发票的税率是多少
  • 出租场地属于什么营业范畴
  • 由第三方代付款开票给对方合规吗
  • 成本核算方法有先进先出法吗
  • 专票手工认证
  • 固定资产分配分录
  • 五险一金可以在手机上交吗
  • 购入固定资产如何摊销
  • 国外出差差旅费
  • 内部损益表
  • 生产的产品不合格作废会计分录
  • 承兑汇票银行背书
  • 营改增通知规定的税收优惠政策
  • 关于设备安装调试的说法
  • 有收入零申报要紧吗
  • 电子税务局如何查进项发票
  • Win11 Dev Build 22000.65开发预览版推送(附更新修复已知问题汇总)
  • 商品入库没有收到发票
  • 购进土地会计分录
  • SwiftBTN.exe - SwiftBTN是什么进程 有啥作用
  • win7系统中病毒怎么办
  • 强制关闭mac系统的快捷键
  • php清空数据表
  • 对于接受捐赠的资产价值,应计入当期损益
  • 增值税一般纳税人资格登记表
  • 购入固定资产如何折旧
  • 辛华达瀑布,加拿大贾斯珀国家公园 (© Schroptschop/Getty Images)
  • 缴纳增值税的会计处理方法
  • 环境保护税的征税范围及计税依据
  • session跨域导致失效
  • vue环境搭建及配置简书
  • 滴滴发票4月1日怎么开
  • f12过滤请求
  • idea配置meaven
  • opencv项目开发实战
  • 税控系统维护费普通发票可以全额抵扣吗
  • 财政零余额账户是什么
  • 赔偿款收据样本
  • 帝国cms phpcms
  • mysql的查询缓存与redis的区别
  • mysql的文件格式有哪些
  • 商场收取租金如何入账
  • 个人股权转让需要评估吗
  • 管理费用属于损益类吗
  • 生产成本中制造费用中包括哪些?
  • 企业累计预扣个税是什么
  • 纳税人减免税申请表怎么填
  • 累计折旧需要分录吗
  • 个税申报工资比实发工资高
  • 企业间拆借资金要交印花税吗
  • 存货盘盈的账务处理入什么费用
  • 人力资源外包服务包括哪些
  • 开票软件服务费全额抵扣怎么做账
  • 收到总公司拨款怎么入账
  • 发票金额比实际支付金额大
  • 注册工贸公司要多少资金
  • 营改增后建筑业税率变化情况
  • 研发费用如何做分录分析
  • mysql优化配置文件
  • 通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据
  • 英文版的windows
  • xp系统怎么用u盘启动电脑
  • 创建一个windows
  • 怎么压缩视频
  • solaris挂载硬盘
  • xp系统怎么隐藏文件
  • win7关闭系统更新在哪里
  • windows10玩游戏卡吗
  • Visual Studio 2013 Tools for Unity安装目录,Visual Studio 2013 Tools.unitypackage
  • nodejs开发gui
  • 下列关于js的说法正确的是
  • jquery可编辑表格插件
  • python深入浅出
  • 安徽省国家税务局通用定额发票
  • 资源税的税目有7个,其中不包括
  • 税务局文化建设实施方案
  • 三门峡哪个小区是原火葬场
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设