位置: 编程技术 - 正文

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

编辑:rootadmin

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

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

在上篇文章给大家介绍了mysql数据库性能优化一,今天继续接着上篇文章给大家介绍数据库性能优化相关知识。具体内容如下所示:

建立适当的索引

说起提高数据库性能,索引是最物美价廉的东西了。不用加内存,不用改程序,不用调sql,只要执行个正确的'create index',查询速度就可能提高百倍千倍,这可真有诱惑力。可是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的I/O。

是不是建立一个索引就能解决所有的问题&#;ename上没有建立索引会怎样&#;

---测试案例命令如下 (最好以 select * from emp e,dept d where e.empno= )

*添加主键

*删除主键

索引的原理说明

没有索引为什么会慢&#;

使用索引为什么会快&#;

索引的代价

1、磁盘占用

2、对dml(update delete insert)语句的效率影响

btree 方式检索,算法复杂度: log2N 次数

哪些列上适合添加索引

1、较频繁的作为查询条件字段应该创建索引

2、唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件

3、更新非常频繁的字段不适合创建索引

4、不会出现在WHERE子句中的字段不该创建索引

索引的类型

&#;主键索引,主键自动的为主索引 (类型Primary)

&#;唯一索引 (UNIQUE)

&#;普通索引 (INDEX)

&#;全文索引 (FULLTEXT) [适用于MyISAM] ——》sphinx + 中文分词 coreseek [sphinx 的中文版 ]

&#;综合使用=>复合索引

简述mysql四种索引的区别

lPRIMARY 索引 =》在主键上自动创建

lUNIQUE 索引=> 只要是UNiQUE 就是Unique索引.(只能在字段内容不重复的情况下,才能创建唯一索引)

lINDEX 索引=>就是普通索引

lFULLTEXT => 只在MYISAM 存储引擎支持, 目的是全文索引,在内容系统中用的多, 在全英文网站用多(英文词独立). 中文数据不常用,意义不大,国内全文索引通常使用 sphinx来完成,全文索引只能在 char varchar text字段创建.

全文索引案例

1.创建表

2.建立全文索引

3.插入数据

这里要注意,对于常见的英文 fulltext 不会匹配,而且插入的语句本身是正确的.

4.看看匹配度

0表示没有匹配到,或者你的词是停止词,是不会建立索引的.

使用全文索引,不能使用like语句,这样就不会使用到全文索引了.

复合索引

索引的使用

建立索引

删除索引

查询索引(均可)

修改索引,我们一般是先删除在重新创建.

查询要使用索引最重要的条件是查询条件中需要使用索引。

下列几种情况下有可能使用到索引:

1,对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用。

2,对于使用like的查询,查询如果是 '%aaa' 不会使用到索引, 'aaa%' 会使用到索引。

下列的表将不使用索引:

1,如果条件中有or,即使其中有条件带索引也不会使用。

2,对于多列索引,不是使用的第一部分,则不会使用索引。

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

3,like查询是以%开头

4,如果列类型是字符串,那一定要在条件中将数据使用引号引用起来。否则不使用索引。(添加时,字符串必须'')

5,如果mysql估计使用全表扫描要比使用索引快,则不使用索引。

测试案例(就在前面的dept表上做演示.)

添加一个主键索引

--测试语句

结果是:

--创建多列索引

--证明对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用

--对于使用like的查询

--如果条件中有or,即使其中有条件带索引也不会使用

--为了演示,我们把复合索引删除,然后只在dname上加入索引.

--如果列类型是字符串,那一定要在条件中将数据使用引号引用起来。否则不使用索引

查看索引的使用情况

大家可以注意:

handler_read_key:这个值越高越好,越高表示使用索引查询到的次数。

handler_read_rnd_next:这个值越高,说明查询低效。

* 这时我们会看到handler_read_rnd_next值很高,为什么,这是因为我们前面没有加索引的时候,做过多次查询的原因.

常用SQL优化

大批量插入数据(MySql管理员) 了解

对于MyISAM:

对于Innodb:

1,将要导入的数据按照主键排序

2,set unique_checks=0,关闭唯一性校验。

3,set autocommit=0,关闭自动提交。

优化group by 语句

默认情况,MySQL对所有的group by col1,col2进行排序。这与在查询中指定order by col1, col2类似。如果查询中包括group by但用户想要避免排序结果的消耗,则可以使用order by

null禁止排序

有些情况下,可以使用连接来替代子查询。

因为使用join,MySQL不需要在内存中创建临时表。(讲解)

如果想要在含有or的查询语句中利用索引,则or之间的每个条件列都必须用到索引,如果没有索引,则应该考虑增加索引(与环境相关 讲解)

***有些情况下,可以使用连接来替代子查询。因为使用join,MySQL不需要在内存中创建临时表

和下面比较就可以说明问题!!

选择合适的存储引擎

MyISAM:默认的MySQL存储引擎。如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性要求不是很高。其优势是访问的速度快。

InnoDB:提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比MyISAM,写的处理效率差一些并且会占用更多的磁盘空间。

Memory:数据存在内存中,服务重启时,数据丢失

MyISAM: 在插入数据时,默认放在最后. ,删除数据后,空间不回收.(不支持事务和外键)

InnoDB 支持事务和外键

对应我们程序员说,常用的存储引擎主要是 myisam / innodb / memory,heap 表

如果选用小原则:

1.如果追求速度,不在乎数据是否一直把保存,也不考虑事务,请选择 memory 比如存放用户在线状态.

2.如果表的数据要持久保存,应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性要求不是很高。选用MyISAM

3.如果需要数据持久保存,并提供了具有提交、回滚和崩溃恢复能力的事务安全,请选用Innodb

选择合适的数据类型

在精度要求高的应用中,建议使用定点数来存储数值,以保证结果的准确性。deciaml 不要用float

对于存储引擎是MyISAM的数据库,如果经常做删除和修改记录的操作,要定时执行optimize table table_name;功能对表进行碎片整理。

日期类型要根据实际需要选择能够满足应用的最小存储的早期类型

对于使用浮点数和定点数的案例说明

对于optimize table 表名 演示

定期执行 optimize table temp2 发现表大小变化,碎片整理完毕

&&对于InnoDB它的数据会存在data/ibdata1目录下,在data/数据库/只有一个 *.frm表结构文件.

关于mysql数据库性能优化二小编就给大家介绍到这里,希望对大家有所帮助!

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

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

MySQL入门教程(五)之表的创建、修改和删除 MySQL为关系型数据库(RelationalDatabaseManagementSystem),这种所谓的"关系型"可以理解为"表格"的概念,一个关系型数据库由一个或数个表格组成。表是DB存储数据

标签: mysql数据库性能优化方法有哪些

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

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

下一篇:Mysql创建通用设备管理信息系统数据库

  • 住宿普通发票怎么做账
  • 税后利润向股东分配股息
  • 风险纳税人是指个人还是单位
  • 含税金额与不含税金额的换算
  • 预缴增值税计算公式方法
  • 递延收益影响当期损益吗
  • 进项多少就开多少的票吗
  • 长期待摊费用摊销年限规定
  • 出口退税发票未稽核可以申报退税吗
  • 没有发票不能税前扣除,所以年底结账前需要检查
  • 企业购入车辆会计分录
  • 红字发票的蓝字发票要退回吗
  • 员工出差车费如何报销
  • 应收账款收回时间怎么体现
  • 应付职工薪酬社保
  • 公司的一些党员特别喜欢健身
  • 劳务费增值税发票是劳务单位开吗
  • 企业拆迁补偿款会计分录
  • 出口业务增值税免抵税额
  • 印花税是填开票金额吗
  • 公司个人所得税怎么申报
  • 业务招待费可以结转下年抵扣吗
  • 对外投资亏损可以记股权投资减少吗
  • 银行手续费做账漏掉
  • 资产账实不符说明
  • 冲费用挂账怎么做账
  • mac终端更新系统
  • 建安企业收取管理费虚开怎么处理
  • bios咋进入
  • 已删除好友的聊天记录
  • 自创商誉的确认
  • 那些收入不用缴税
  • windows7中可以设置控制计算机
  • php企业管理系统
  • 资产处置损益计税基础是什么
  • 存货报废如何账务处理
  • 蛇形矩阵找数的位置
  • 企业所得税税前扣除和不扣除的区别
  • 期间费用计入产品成本的费用吗
  • 有利润但不交企业所得税
  • 运动目标检测算法
  • 专票如何申领
  • php路径问题
  • emerge命令
  • diff比较文件不同输出
  • html获取php数据
  • 火车及机票退票扣多少钱
  • 融资租赁利息一般多少
  • mongodb的索引种类
  • 民办非企业的税务登记国税还是地税
  • 视同小规模纳税人是有?
  • 开票只开大类
  • 营改增之后账务怎么处理
  • 上年多交的增值税怎么调整
  • 公允价值怎么读
  • 企业贷款受托支付如何收税
  • 当月进项票没有开进来
  • 进项税加计抵减的分录怎么做?
  • 什么差旅费
  • 销售出库单需要盖章吗
  • 购买服装费用计入什么科目
  • 经济往来怎么写
  • 繁体系统安装简体软件
  • freebsd 升级
  • ctrmon.exe
  • spmgr.exe - spmgr是什么进程 有什么用
  • explorer.exe是什么指令
  • 查找返回一行数据
  • win8操作中心
  • Linux运维工程师工作内容
  • Linux安装anaconda
  • win8系统自带浏览器
  • cocos2dx怎么用
  • python如何将矩阵转为图像
  • unity地形少了三个键
  • 咨询服务合同属于购销合同吗
  • 河南省国家税务总局网站
  • 混合销售定义是什么意思
  • 北京市东城分局刑侦大队电话
  • 德国对外投资法律劣势有哪些方面
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设