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. gsap

    TweenMax借助于css,轻量级的js库 下面是简单的demo <!DOCTYPE html> <html lang="en"> <head> ...

  2. 02_Redis数据类型(String、Hash)

    [Redis数据类型] redis是通过key-Value来存储的,其支持的数据类型如下: 1.字符串 2.Hash 3.List 4.Set 5.SortSet(zset) 注:redis中,命令( ...

  3. Java—集合框架 List的 indexOf()、lastIndexOf()

    集合中某个元素出现的位置—List的indexOf(),lastIndexOf() indexOf(Object obj)方法的实现机制是从序列(List)的第0个元素开始依次循环,并且调用每个元素的 ...

  4. HTTP Strict Transport Security

    HTTP Strict Transport Security (通常简称为HSTS) 是一个安全功能,它告诉浏览器只能通过HTTPS访问当前资源, 禁止HTTP方式. 作用 一个网站接受一个HTTP的 ...

  5. Flask入门request session cookie(二)

    1 HTTP方法分类 1 GET 浏览器告知服务器:只获取页面上的信息并发给我.这是最常用的方法. 2 HEAD 浏览器告诉服务器:欲获取信息,但是只关心消息头 .应用应像处理 GET 请求一样来处理 ...

  6. OFBiz部署与运行

    下载及部署命令:http://ofbiz.apache.org/download.html OFBiz的安装部署是基于ant的,官网的案例是执行load-demo任务和start任务.以下分析是以12 ...

  7. linux虚拟机最优测试环境搭建

    目标:创建一个最优的linux虚拟机环境 环境:vmware12.0 系统:centos6.5 (* 以下配置是建立在配置完成基础网络环境后创建的,用static静态IP地址) 1.关闭selinux ...

  8. [原]Machine Learing 入门 —— 开门第0篇

    一.最近懒了 7月没怎么写博客,倒是一直在学Machine Learning的入门知识,在这里给大家推荐一个不错的自学网站:https://www.coursera.org/ ,Andrew Ng是联 ...

  9. 使用 Android 客户端向 Ruby on rails 构建的 Web Application 提交 HTTP GET 和 HTTP POST 请求

    最近想弄个能访问 Internet 的 Android 应用,因为求快所以用了 Ruby on Rails 来提供 HTTP 资源.这方面的资料还是比较少的,所以把尝试的过程记录下来. 1 使用 Ru ...

  10. sublime text3 英文版转为中文版

    第一步设置好:https://packagecontrol.io/installation#st3 简单几步 : 1. 点击菜单栏中“preferences”,弹出选项中找到“package cont ...