MYSQL的优化一个很棘手的问题,也是一个公司最想处理得当的问题.

  那么今天,本人为大家带来几点优化数据库的方法:

  1.选取最适用的字段属性

    一般来说,数据库的的表越小,在其上面执行的查询也会越快.因此,我们在设计表的时候可以将表中的宽度设的尽可能的小.

    对于字段来说,,我们尽量和值为NOT NULL,这样在查询时,数据库不用比较NULL值

    对于某些文本字段,可以用ENUM类型来对该字段下的数值进行限制.

  2.使用JOIN来代替子查询

    了解mysql的人都知道,使用子查询可以一次性的完成很多逻辑上的需要多个复杂步骤才能完成的SQL操作,但是这样的查询会大大降低查询的速率

    如果使用JOIN来完成此项工作的话,速度会快很多.

    JOIN之所以效率很高.是因为MYSQL不需要在内存中创建临时表来完成这个逻辑上的两个步骤的查询工作.

  3.UNION来代替手动创建的临时表

    mysql从4.0版本开始支持联合查询.

    它可以把需要使用临时表的两条或更多的select查询合并的一个查询中,在客户端的查询会话结束的时候,临时表会自动删除

    从而保证数据库整齐,高效.

  4.事务

    尽管使用子查询,JOIN和UNION来创建各种查询.但并不是所有的操作都可以用一条或几条SQL语句就可以完成的

    为了防止数据库出现意外.就要使用事务,推荐使用InnoDB引擎

    其作用是可以保持数据库数据的一致性和完整性.

    另一个作用则是在多个用户同时使用相同的数据源时,它可以锁定数据库的方法来为童虎提供一种安全的访问方式

  5.锁定表

    事务虽好,可由于它的独占性,有时会影响数据库的性能.假设有成千上万的用户同时访问一个数据库,就会产生比较严重的响应延迟

    那么锁定表,就可以起到维护数据完整性的作用,来获得更好的性能.

  6.使用外键

    锁定表也有它的弊端,那就是它不能保证数据的关联性.这个时候,我们就可以使用外键.

    注意,引擎要用innodb而不是myisam类型

  7.使用索引

    索引是提高数据性能的常用方法,它可以令数据库服务器以比没有索引快的多的速度检索特定的行,尤其是在查询语句中包含MAX(),MIN()和ORDER BY 这些命令的时候,性能提高更为明显.

    一般来说,索引应建立在那些用于JOIN ,WHERE 判断 和ORDER BY 排序的字段上,尽可能不要对数据库中某个含有大量重复值的字段建立索引.

  8.优化的查询语句

    绝大多数下,用索引可以提高查询的速度,但是如果SQL语句使用不恰当的话,索引将无法发挥作用.

    那么该注意以下几个方面:

      1.最好在相同类型的字段间进行比较的操作

      2.在建有索引的字段上尽量不要使用函数进行操作.

      3.在搜索字符型字段时,我们有时会使用LIKE关键字和通配符,这种做法虽然简单,但也是以牺牲系统性能为代价的操作.

    最后,应该注意避免在查询中让MYSQL进行自动类型转换,因为转换过程也会让索引变得不起作用!

以上,就是我为大家总结的几点关于优化数据库的操作,仅供参考,若有雷同,实属巧合!

                                                              ------作者 恋夏啊   2019-1-3

关于mysql的优化的更多相关文章

  1. Mysql - 性能优化之子查询

    记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...

  2. Mysql性能优化三(分表、增量备份、还原)

    接上篇Mysql性能优化二 对表进行水平划分 如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了.如果我拆成100个表,那么每个表只有10万条记录.当然这需要数据在逻 ...

  3. Mysql性能优化一

    下一篇:Mysql性能优化二 mysql的性能优化无法一蹴而就,必须一步一步慢慢来,从各个方面进行优化,最终性能就会有大的提升. Mysql数据库的优化技术 对mysql优化是一个综合性的技术,主要包 ...

  4. 关于MySQL数据库优化的部分整理

    在之前我写过一篇关于这个方面的文章 <[原创]为什么使用数据索引能提高效率?(本文针对mysql进行概述)(更新)> 这次,主要侧重点讲下两种常用存储引擎. 我们一般从两个方面进行MySQ ...

  5. [MySQL性能优化系列]提高缓存命中率

    1. 背景 通常情况下,能用一条sql语句完成的查询,我们尽量不用多次查询完成.因为,查询次数越多,通信开销越大.但是,分多次查询,有可能提高缓存命中率.到底使用一个复合查询还是多个独立查询,需要根据 ...

  6. [MySQL性能优化系列]巧用索引

    1. 普通青年的索引使用方式 假设我们有一个用户表 tb_user,内容如下: name age sex jack 22 男 rose 21 女 tom 20 男 ... ... ... 执行SQL语 ...

  7. 【MySQL】花10分钟阅读下MySQL数据库优化总结

    1.花10分钟阅读下MySQL数据库优化总结http://www.kuqin.com2.扩展阅读:数据库三范式http://www.cnblogs.com3.my.ini--->C:\Progr ...

  8. MySQL性能优化:索引

    MySQL性能优化:索引 索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序.数据库使用索引以找到特定值,然后顺指针找到包含该值的行.这样可以使对应于表的SQL语句执 ...

  9. 30多条mysql数据库优化方法,千万级数据库记录查询轻松解决(转载)

    1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...

  10. mysql 性能优化方向

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

随机推荐

  1. Hibernate中的一对一注解配置

    Card类 package cn.OneToOne2017109.entity; import javax.persistence.*; /** * Created by YSS on 2017/10 ...

  2. ECharts动态数据加载

    最近有用到ECharts做可视化报表,小结一下 一.准备数据 1.官网下载echarts.min.js 2.引入jquery.js 3.请求用的json数据 { "list":[ ...

  3. maven项目的创建

    ·做了两年多Java Web一多半的项目都是SSM架构的,只搭建过两次,趁着周末做个总结整理. Eclipse搭建Maven项目 1.new project  --> Maven project ...

  4. 沙箱模式的chrome浏览器的运行

    getUserMedia在chrome 47后已经不可以从非安全源访问(Insecure Origins),但测试搭建apprtc时服务器一般没有添加HTTPS安全验证,chrome就没有权限访问麦克 ...

  5. js简单实现表格排序

    昨天看到一篇关于表格排序的随笔,鉴于本人还只会简单的js,不会使用封装,所以自己也试了一下写这个效果.可能不太优化,原理思路是:获取行对象tr,排序tr中要比较的对象td,排序后添加回tbody.如下 ...

  6. 统计学中的P值与显著性的意义

    统计学意义(p值) 结果的统计学意义是结果真实程度(能够代表总体)的一种估计方法.专业上,p值为结果可信程度的一个递减指标,p值越大,我们越不能认为样本中变量的关联是总体中各变量关联的可靠指标.p值是 ...

  7. 通过调用Word模板(Doc、dot)直接打印 z

    通过替换模板中的指定 书签 来进行内容的替换.整合,然后直接发送到打印打印,也可以导出.即把打印出的语句换成保存函数. public static class myPrintByOffice      ...

  8. GO Lang学习笔记 - 基础知识

    Go lang Learn Note 标签(空格分隔): Go Go安装和Go目录 设置环境变量GOROOT和GOPATH,前者是go的安装目录,后者是开发工作目录.go get包只会将包下载到第一个 ...

  9. 网络防火墙之iptables的前世今生和归宿

    任何事物都有一个从无到有,再归于无的过程.是的,我这里用了一个绝对词:任何. 防火墙 在计算机领域中,防火墙(英文:Firewall)是一项协助确保信息安全的设备,会依照特定的规则,允许或是限制传输的 ...

  10. python:常用模块二

    1,hashlib模块---摘要算法 import hashlib md5 = hashlib.md5() md5.update('how to use md5 in python hashlib?' ...