关于mysql的优化
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的优化的更多相关文章
- Mysql - 性能优化之子查询
记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...
- Mysql性能优化三(分表、增量备份、还原)
接上篇Mysql性能优化二 对表进行水平划分 如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了.如果我拆成100个表,那么每个表只有10万条记录.当然这需要数据在逻 ...
- Mysql性能优化一
下一篇:Mysql性能优化二 mysql的性能优化无法一蹴而就,必须一步一步慢慢来,从各个方面进行优化,最终性能就会有大的提升. Mysql数据库的优化技术 对mysql优化是一个综合性的技术,主要包 ...
- 关于MySQL数据库优化的部分整理
在之前我写过一篇关于这个方面的文章 <[原创]为什么使用数据索引能提高效率?(本文针对mysql进行概述)(更新)> 这次,主要侧重点讲下两种常用存储引擎. 我们一般从两个方面进行MySQ ...
- [MySQL性能优化系列]提高缓存命中率
1. 背景 通常情况下,能用一条sql语句完成的查询,我们尽量不用多次查询完成.因为,查询次数越多,通信开销越大.但是,分多次查询,有可能提高缓存命中率.到底使用一个复合查询还是多个独立查询,需要根据 ...
- [MySQL性能优化系列]巧用索引
1. 普通青年的索引使用方式 假设我们有一个用户表 tb_user,内容如下: name age sex jack 22 男 rose 21 女 tom 20 男 ... ... ... 执行SQL语 ...
- 【MySQL】花10分钟阅读下MySQL数据库优化总结
1.花10分钟阅读下MySQL数据库优化总结http://www.kuqin.com2.扩展阅读:数据库三范式http://www.cnblogs.com3.my.ini--->C:\Progr ...
- MySQL性能优化:索引
MySQL性能优化:索引 索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序.数据库使用索引以找到特定值,然后顺指针找到包含该值的行.这样可以使对应于表的SQL语句执 ...
- 30多条mysql数据库优化方法,千万级数据库记录查询轻松解决(转载)
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
- mysql 性能优化方向
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
随机推荐
- git添加远程库基本操作
git添加远程库的基本步骤: 1.登录github,创建一个仓库,最好和本地仓库同名 2.输入git指令,把路径改成本地仓库所在盘符,如图 (project_03是我的本地仓库名称,路径是在G盘的WW ...
- flask-session总结
一.session session和cookie的原理和区别: cookie是保存在浏览器上的键值对 session是存在服务端的键值对(服务端的session就是 ...
- MockPlus的使用方法简介
不废话直接上图,不明白的留言.
- Homebrew 的使用
安装 /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/ins ...
- Eclipse中搭建Android开发环境
一.搭建Android开发环境 准备工作:下载Eclipse.JDK.Android SDK.ADT插件 下载地址:Eclipse:http://www.eclipse.org/downloads/ ...
- POJO对象
POJO(Plain Old Java Objects)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混淆所创造的简称. 使用POJO名称是为了避免和 EJB混淆起来, 而且简 ...
- 数据结构复习之C语言指针与结构体
数据结构指针复习: #include <stdio.h> void main() { ] = {, , , , }; // a[3] == *(3+a) printf(+a)); // a ...
- Eclipse equinox implementation of OSGi
Bundle package org.osgi.framework; public interface Bundle extends Comparable<Bundle> { int UN ...
- 源码安装mysql5.6.37
MYSQL 源码安装: 修改参数文件:vi /etc/security/limits.confmysql soft nproc 2047mysql hard nproc 16384mysql soft ...
- 长大Tips的第二步
由于期末将至的缘故,组员们对于这次项目都开始表现出了懈怠的情绪,故而这一次并没有完成许多实质性的任务,相较于上一次,此次增添了登陆以及注册的功能,说来惭愧,虽然已经学习了数据库编程,可惜自己学艺不精并 ...